赎金信(C++)

简介: 赎金信(C++)

赎金信

给你两个字符串:ransomNote和 magazine,判断 ransomNote能不能由 magazine里面的字符构成。

如果可以,返回 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由小写英文字母组成

我的代码:

class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        // 本质上还是一个字符统计问题
        if (ransomNote.size() > magazine.size()) return false;
        vector<int> cnt(30);
        for (auto c : magazine) cnt[c - 'a'] ++;
        for (auto c : ransomNote)
        {
            cnt [c - 'a'] --;
            if (cnt[c - 'a'] < 0)  return false;
        }
        return true;
    }
};


相关文章
|
7月前
|
Java C++ Python
leetcode-383:赎金信
leetcode-383:赎金信
52 1
|
算法 索引
LeetCode每日1题--赎金信
LeetCode每日1题--赎金信
63 0
|
算法 Java
. 赎金信(java算法)
. 赎金信(java算法)
65 0
. 赎金信(java算法)
|
算法 Java Python
赎金信 (LeetCode 383)
赎金信 (LeetCode 383)
178 0
|
Go Python
力扣383. 赎金信
力扣383. 赎金信
247 0
|
安全 数据安全/隐私保护