LeetCode热题100--383
LeetCode热题100–383. 赎金信
题目链接
题目类型: 哈希表、字符串
-
给你两个字符串:
ransomNote和magazine,判断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 <= 105ransomNote和magazine由小写英文字母组成
代码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[]来记录每个字符出现的次数。
但是我们有两个字符串magazine和ransomNote,我们需要看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; }};


