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;
    }
};
相关推荐
昵称小白1 天前
复杂度分析方法
算法
科研前沿1 天前
2026 数字孪生前沿科技:全景迭代报告 —— 镜像视界生成式孪生(Generative DT)技术白皮书
大数据·人工智能·科技·算法·音视频·空间计算
学涯乐码堂主1 天前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
切糕师学AI1 天前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
Tutankaaa1 天前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073211 天前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee1 天前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99901 天前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5051 天前
深入理解主成分分析(PCA)
算法
apollowing1 天前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app