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

Posted Kinght_123

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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

运行结果

以上是关于LeetCode:383. 赎金信————简单的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 383 赎金信

LeetCode 383 赎金信[数组] HERODING的LeetCode之路

LeetCode 383. 赎金信 / 372. 超级次方 / 1816. 截断句子

20.4.12 赎金信 简单

leetcode 简单 第八十九题 赎金信

Leetcode刷题100天—383. 赎金信( 数组)—day79