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;
    }
};
相关推荐
科大饭桶2 小时前
数据结构自学Day13 -- 快速排序--“分而治之”
数据结构·算法·排序算法
技术卷3 小时前
详解力扣高频SQL50题之1148. 文章浏览 I【入门】
sql·leetcode·oracle
某个默默无闻奋斗的人3 小时前
【矩阵专题】Leetcode54.螺旋矩阵(Hot100)
java·算法·leetcode
JXL18604 小时前
Leetcode-.42接雨水
算法·leetcode·职场和发展
啊我不会诶5 小时前
CF每日5题(1500-1600)
c++·学习·算法
巴伦是只猫6 小时前
Java 高频算法
java·开发语言·算法
点云SLAM6 小时前
C++中std::string和std::string_view使用详解和示例
开发语言·c++·算法·字符串·string·c++标准库算法·string_view
原来是猿6 小时前
list 介绍 及 底层
数据结构·c++·list
88号技师6 小时前
2025年7月Renewable Energy-冬虫夏草优化算法Caterpillar Fungus Optimizer-附Matlab免费代码
开发语言·人工智能·算法·matlab·优化算法
dragoooon347 小时前
优选算法:移动零
c++·学习·算法·学习方法