题目链接: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 <= 105
ransomNote
?和?magazine
?由小写英文字母组成
文章讲解:代码随想录
思路:题目中提到两个字符串由小写字母组成,因此可以把长度为数组用作哈希表存储 magazine 中的每个字符出现的次数。再遍历 ransomNote,在哈希表中查找有没有足够的当前字符。
/**
* @param {string} ransomNote
* @param {string} magazine
* @return {boolean}
*/
var canConstruct = function(ransomNote, magazine) {
const arr = new Array(26).fill(0);
for (const i in magazine) {
arr[magazine.charCodeAt(i) - "a".charCodeAt()]++;
}
for (const i in ransomNote) {
if (arr[ransomNote.charCodeAt(i) - "a".charCodeAt()]) {
arr[ransomNote.charCodeAt(i) - "a".charCodeAt()]--
} else {
return false;
}
}
return true;
};
分析:时间复杂度为 O(n),空间复杂度为 O(1)。
当判断一个元素有没有有在集合中时,就可以使用哈希表。