94 - 赎金信
题目
给定一个赎金信 (ransom) 字符串和一个杂志(magazine)字符串,判断第一个字符串ransom能不能由第二个字符串magazines里面的字符构成。如果可以构成,返回 true ;否则返回 false。
(题目说明:为了不暴露赎金信字迹,要从杂志上搜索各个需要的字母,组成单词来表达意思。)
注意:
你可以假设两个字符串均只含有小写字母。
canConstruct("a", "b") -> false canConstruct("aa", "ab") -> false canConstruct("aa", "aab") -> true
解答
怎么和两个数组的交集那么像呢。。建一个哈希表咯
hash
var canConstruct = function (ransomNote, magazine) {
let hash = new Map()
for (let i = 0; i < magazine.length; i++) {
if (hash.has(magazine[i])) {
hash.set(magazine[i], hash.get(magazine[i]) + 1)
} else {
hash.set(magazine[i], 1)
}
}
for (let i = 0; i < ransomNote.length; i++) {
const element = ransomNote[i];
if (!hash.has(element)) {
return false
}
if (hash.get(element) > 1) {
hash.set(element, hash.get(element) - 1)
} else {
hash.delete(element)
}
}
return true
};Runtime: 76 ms, faster than 80.83% of JavaScript online submissions for Ransom Note.
Memory Usage: 37.1 MB, less than 100.00% of JavaScript online submissions for Ransom Note.
Runtime: 16 ms, faster than 38.93% of Go online submissions for Ransom Note.
Memory Usage: 4.3 MB, less than 100.00% of Go online submissions for Ransom Note.
用数组存
Runtime: 60 ms, faster than 98.00% of JavaScript online submissions for Ransom Note.
Memory Usage: 36.7 MB, less than 100.00% of JavaScript online submissions for Ransom Note.
Runtime: 4 ms, faster than 94.70% of Go online submissions for Ransom Note.
Memory Usage: 4.3 MB, less than 100.00% of Go online submissions for Ransom Note.
Last updated
Was this helpful?