LeetCode热题100--383

LeetCode热题100--383. 赎金信

题目链接

题目类型: 哈希表、字符串

  • 给你两个字符串:ransomNotemagazine ,判断 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
    • ransomNotemagazine 由小写英文字母组成

代码1(STL--unordered_map)

c++ 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        int cnt[30];

        for(int i=0;i<magazine.size();i++)
        {
            cnt[magazine[i]-'a']++;
        }
        for(int i=0;i<ransomNote.size();i++)
        {
            cnt[ransomNote[i]-'a']--;
            if(cnt[ransomNote[i]-'a'] < 0 ) 
            {
                return false;
            }
        }
        return true;
    }
};

这样做会造成额外的空间复杂度,实际上,我们需要统计的字符数只有a-z26个,所以可以直接使用一个int数组cnt[]来记录每个字符出现的次数。

但是我们有两个字符串magazineransomNote,我们需要看ransomNote里的每个字符的数量是否严格小于magazine中的对应字符数量,如果不成立则返回false

代码2(int数组)

C++ 复制代码
class Solution {
public:
    bool canConstruct(string ransomNote, string magazine) {
        int cnt[30];

        for(int i=0;i<magazine.size();i++)
        {
            cnt[magazine[i]-'a']++;
        }
        for(int i=0;i<ransomNote.size();i++)
        {
            cnt[ransomNote[i]-'a']--;
            if(cnt[ransomNote[i]-'a'] < 0 ) 
            {
                return false;
            }
        }
        return true;
    }
};
相关推荐
驭渊的小故事21 小时前
多线程01(线程状态和线程的sleep,线程终止(Interrupt)的小关联)
java·jvm·算法
hansang_IR1 天前
【记录】loj2967「COCI 2010.03.06」PROGRAM
c++·算法
心中有国也有家1 天前
PaddlePaddle 适配 NPU 的技术全解析——从算子接入到端到端性能优化
人工智能·分布式·算法·性能优化·架构·paddlepaddle
兰令水1 天前
topcode【随机算法题】【2026.5.24打卡-java版本】
java·开发语言·算法
徐小夕1 天前
面试官:AI生成到90%突然断了,你的解决方案是什么?(万字长文深度剖析)
前端·vue.js·算法
EnCi Zheng1 天前
09a-斯坦福 CS336 作业一:BPE分词器
开发语言·python·算法
生成论实验室1 天前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
霍霍的袁1 天前
【C++初阶】缺省参数(默认参数)详细讲解
开发语言·c++·算法
计算机安禾1 天前
【算法分析与设计】第2篇:计算模型与渐进复杂性分析
算法
生成论实验室1 天前
事件、信息荷与六维态势空间——每一个事件都是一次空间的弯曲
人工智能·算法·语言模型·可信计算技术·安全架构