LeetCode:383. 赎金信————简单

题目

383. 赎金信
为了不在赎金信中暴露字迹,从杂志上搜索各个需要的字母,组成单词来表达意思。

给你一个赎金信 (ransomNote) 字符串和一个杂志(magazine)字符串,判断 ransomNote 能不能由 magazines 里面的字符构成。

如果可以构成,返回 true ;否则返回 false 。

magazine 中的每个字符只能在 ransomNote 中使用一次。

示例 1:
输入:ransomNote = "a", magazine = "b"
输出:false

示例 2:
输入:ransomNote = "aa", magazine = "ab"
输出:false

示例 3:
输入:ransomNote = "aa", magazine = "aab"
输出:true
 

提示:
1 <= ransomNote.length, magazine.length <= 105
ransomNote 和 magazine 由小写英文字母组成

解题思路

  • 首先利用collections.Counter()函数统计一下杂志里的字符串的个数。
  • 然后遍历赎金信,如果赎金信里的字符串不在杂志里,那么返回False;否则杂志里对应赎金信的字符串的个数减1;如果杂志里的字符串的个数出现负数的情况,结果依然为False;最后返回True

Code

class Solution:
    def canConstruct(self, ransomNote: str, magazine: str) -> bool:
        if len(ransomNote) > len(magazine):
            return False
        dic = collections.Counter(magazine)
        for i in ransomNote:
            if i not in dic:
                return False
            dic[i] -= 1
            if dic[i] < 0:
                return False
        return True

运行结果

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
THE END
分享
二维码
< <上一篇
下一篇>>