aboutsummaryrefslogtreecommitdiff
path: root/challenge-004/zapwai/javascript/ch-2.js
blob: cdcb8528e62c1246691bba5f0579c7653b7e187d (plain)
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
let allow = "docgotrark";
proc(allow);

function proc(allow) {
    let f = {}			// hash containing allowed letters & counts
    fill(f, allow);
    let words = ["dog", "chair", "rack", "doggo"];
    let ans = [];
    for (let word of words) {
	let g = {};
	fill(g, word);
	if (comp(f,g) == 1) {
	    ans.push(word);
	}
    }
    console.log("Input:", allow);
    console.log("Output:", ans);
}
// fills a hashmap to count letters
function fill(f, word) {
    for (let c of word) {
	f[c] = 0;
    }
    for (let c of word) {
	f[c]++;
    }
}
// compare hashes, f is allowed chars, g is the word
function comp(f,g) {
    for (let k of Object.keys(g)) {
	if (!(k in f)) {
	    return 0;
	}
	if (f[k] < g[k]) {
	    return 0;
	}
    }
    return 1;
}