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 赎金信[数组] HERODING的LeetCode之路