赎金信(判断一个字符串是都可以通过另一个字符串进行转化)

 

这个题目属于简单的类型,使用字典来进行词频统计,如果ransomNote 中key的个数大于magazine,或者ransomNote的key在magazine中找不到,就返回False。

复制代码
class Solution:
    def canConstruct(self, ransomNote: str, magazine: str) -> bool:
        m_dict={}
        r_dict={}
        # 统计ransomNote和magazine字母出现的个数

        for m_i in magazine:
            if m_i not in m_dict:
                m_dict[m_i]=1
            else:
                m_dict[m_i]+=1
        
        for r_i in ransomNote:
            if r_i not in r_dict:
                r_dict[r_i]=1
            else:
                r_dict[r_i]+=1
        
        flag=True
        for r_key,r_value in r_dict.items():
            # 如果 ransomNote 字符出现的个数大于 magazine字符出现的个数 或者 ransomNote中的字符 在magazine中没有 直接break
            if r_key not in m_dict or r_value>m_dict[r_key]:
                flag=False
                break
        return flag
            
复制代码

 

posted @   TW-NLP  阅读(5)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示