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 小时前
优选算法——滑动窗口
c++·算法·leetcode
csdn_aspnet1 小时前
奈飞工厂算法:个性化推荐系统的极限复刻
算法·netflix·奈飞
小白_ysf1 小时前
Vue 中常见的加密方法(对称、非对称、杂凑算法)
前端·vue.js·算法
多米Domi0112 小时前
0x3f 第49天 面向实习的八股背诵第六天 过了一遍JVM的知识点,看了相关视频讲解JVM内存,垃圾清理,买了plus,稍微看了点确定一下方向
jvm·数据结构·python·算法·leetcode
L_090711 小时前
【C++】高阶数据结构 -- 红黑树
数据结构·c++
A_nanda11 小时前
c# MOdbus rto读写串口,如何不相互影响
算法·c#·多线程
代码雕刻家12 小时前
2.4.蓝桥杯-分巧克力
算法·蓝桥杯
Ulyanov13 小时前
顶层设计——单脉冲雷达仿真器的灵魂蓝图
python·算法·pyside·仿真系统·单脉冲
智者知已应修善业14 小时前
【查找字符最大下标以*符号分割以**结束】2024-12-24
c语言·c++·经验分享·笔记·算法
划破黑暗的第一缕曙光14 小时前
[数据结构]:5.二叉树链式结构的实现1
数据结构