题目链接: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
由小写英文字母组成
文章讲解:代码随想录
题解1:哈希表
思路:题目中提到两个字符串由小写字母组成,因此可以把长度为数组用作哈希表存储 magazine 中的每个字符出现的次数。再遍历 ransomNote,在哈希表中查找有没有足够的当前字符。
javascript
/**
* @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)。
收获
当判断一个元素有没有有在集合中时,就可以使用哈希表。