> 技术文档 > LeetCode热题100--383

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)

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数组)

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; }};