赎金信(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;
    }
};


相关文章
|
4月前
|
Java C++ Python
leetcode-383:赎金信
leetcode-383:赎金信
40 1
|
3月前
|
安全
在遭遇勒索软件攻击后是支付赎金还是不支付赎金?
在遭遇勒索软件攻击后是支付赎金还是不支付赎金?
|
算法 索引
LeetCode每日1题--赎金信
LeetCode每日1题--赎金信
56 0
|
算法 Java Python
赎金信 (LeetCode 383)
赎金信 (LeetCode 383)
164 0
|
Web App开发 存储 安全
|
存储 安全 算法
比特币钱包遭暴力破解的真相竟是为了挖宝
本文讲的是比特币钱包遭暴力破解的真相竟是为了挖宝,近日,一个被称为“ Large Bitcoin Collider”的组织已经暴力破解了数个比特币钱包,其中有三个钱包里含有比特币。目前尚不清楚该组织的目的是金钱还是挑战技能。
2552 0