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;
    }
};
相关推荐
Dream it possible!2 分钟前
LeetCode 面试经典 150_哈希表_快乐数(45_202_C++_简单)(哈希表;快慢指针)
leetcode·面试·散列表
IT成长日记21 分钟前
【LVS入门宝典】LVS调度算法轮询(RR)深度解析:从原理到实战的公平调度之道
算法·lvs·rr·轮询调度算法
NAGNIP40 分钟前
一文搞懂量化、剪枝和知识蒸馏都是什么?
算法
点云SLAM1 小时前
GTSAM 中自定义因子(Custom Factor)的详解和实战示例
算法·机器人·slam·后端优化·gtsam·gtsam自定义因子·因子图
萘柰奈2 小时前
LeetCode刷题记录----62.不同路径(Medium)
算法·leetcode·职场和发展
日落辞朝阳2 小时前
数据结构——顺序表
数据结构
阳光明媚sunny2 小时前
爬楼梯算法java实现
算法·动态规划
Z_z在努力2 小时前
【数据结构】哈希表(Hash Table)详解
数据结构·哈希算法·散列表
贝塔实验室2 小时前
LDPC码的概念
科技·学习·程序人生·算法·学习方法·程序员创富·改行学it
weixin_307779132 小时前
矩形势阱(V(x) = -H for |x|≤L)的束缚态能级求解与宇称分类
算法