赎金信--leetcode

  • 赎金信

给你两个字符串: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

cpp 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        if (ransomNote.empty()) {
            return true;
        }
        if (magazine.empty()) {
            return false;
        }
        if (magazine.size() < ransomNote.size()) {
            return false;
        }
        // int* record = new int[26];
        vector<int> record(26, 0);
        for (const auto& c : magazine) {
            record[c - 'a']++;
        }

        for (const auto& c : ransomNote) {
            record[c - 'a']--;
            if (record[c - 'a'] < 0) {
                return false;
            }
        }

        return true;
    }
};
相关推荐
qq_4335545414 小时前
C++数位DP
c++·算法·图论
AshinGau14 小时前
Softmax 与 交叉熵损失
神经网络·算法
似水এ᭄往昔14 小时前
【C++】--AVL树的认识和实现
开发语言·数据结构·c++·算法·stl
栀秋66615 小时前
“无重复字符的最长子串”:从O(n²)哈希优化到滑动窗口封神,再到DP降维打击!
前端·javascript·算法
xhxxx15 小时前
不用 Set,只用两个布尔值:如何用标志位将矩阵置零的空间复杂度压到 O(1)
javascript·算法·面试
有意义15 小时前
斐波那契数列:从递归到优化的完整指南
javascript·算法·面试
charlie11451419115 小时前
编写INI Parser 测试完整指南 - 从零开始
开发语言·c++·笔记·学习·算法·单元测试·测试
mmz120715 小时前
前缀和问题2(c++)
c++·算法
TL滕15 小时前
从0开始学算法——第十六天(双指针算法)
数据结构·笔记·学习·算法
蒲小英16 小时前
算法-贪心算法
算法·贪心算法