-
Notifications
You must be signed in to change notification settings - Fork 24
/
0383-ransom-note.js
49 lines (37 loc) · 1.26 KB
/
0383-ransom-note.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
// 383. Ransom Note
// Easy 47%
// Given an arbitrary ransom note string and another string containing letters
// from all the magazines, write a function that will return true if the ransom
// note can be constructed from the magazines ; otherwise, it will return false.
// Each letter in the magazine string can only be used once in your ransom note.
// Note:
// You may assume that both strings contain only lowercase letters.
// canConstruct("a", "b") -> false
// canConstruct("aa", "ab") -> false
// canConstruct("aa", "aab") -> true
/**
* @param {string} ransomNote
* @param {string} magazine
* @return {boolean}
*/
const canConstruct = function(ransomNote, magazine) {
const hash = {}
for (let c of magazine) hash[c] = (hash[c] || 0) + 1
for (let c of ransomNote) {
if (!hash[c]) return false
hash[c]--
}
return true
}
;[
['a', 'b'], // false
['aa', 'ab'], // false
['aa', 'aab'], // true
].forEach(args => {
console.log(canConstruct(...args))
})
// Solution:
// 第一次遍历,用哈希表保存 s 字符串中的字符及其个数。
// 第二次遍历,遇到字符不存在或其数量为 0 时,返回 false。
// 都存在且够用,则返回 true。
// Submission Result: Accepted