6 and 8
This commit is contained in:
1
08/input-test.txt
Normal file
1
08/input-test.txt
Normal file
@ -0,0 +1 @@
|
||||
2 3 0 3 10 11 12 1 1 0 1 99 2 1 1 2
|
1
08/input.txt
Normal file
1
08/input.txt
Normal file
File diff suppressed because one or more lines are too long
28
08/part1.js
Normal file
28
08/part1.js
Normal file
@ -0,0 +1,28 @@
|
||||
var input = require("fs").readFileSync("input.txt").toString().replace("\n", "");
|
||||
var nums = input.split(" ").map(a=>(parseInt(a)));
|
||||
|
||||
function parseTree(ints){
|
||||
var numChildren = ints[0];
|
||||
var numMeta = ints[1];
|
||||
var children = [];
|
||||
|
||||
var i = 0;
|
||||
while(numChildren > 0){
|
||||
var childParsed = parseTree(ints.slice(2 + i));
|
||||
i += childParsed[1].length;
|
||||
children.push(childParsed[0]);
|
||||
numChildren--;
|
||||
}
|
||||
return [{children: children, meta: ints.slice(2+i, 2+i+numMeta)}, ints.slice(0, 2+i+numMeta)]
|
||||
}
|
||||
|
||||
function treeMetaTotal(tree){
|
||||
var total = 0;
|
||||
for(var child of tree.children){
|
||||
total += treeMetaTotal(child);
|
||||
}
|
||||
total += tree.meta.reduce((a,b)=>(a+b));
|
||||
return total;
|
||||
}
|
||||
|
||||
console.log(treeMetaTotal(parseTree(nums)[0]));
|
29
08/part2.js
Normal file
29
08/part2.js
Normal file
@ -0,0 +1,29 @@
|
||||
var input = require("fs").readFileSync("input.txt").toString().replace("\n", "");
|
||||
var nums = input.split(" ").map(a=>(parseInt(a)));
|
||||
|
||||
function parseTree(ints){
|
||||
var numChildren = ints[0];
|
||||
var numMeta = ints[1];
|
||||
var children = [];
|
||||
|
||||
var i = 0;
|
||||
while(numChildren > 0){
|
||||
var childParsed = parseTree(ints.slice(2 + i));
|
||||
i += childParsed[1].length;
|
||||
children.push(childParsed[0]);
|
||||
numChildren--;
|
||||
}
|
||||
return [{children: children, meta: ints.slice(2+i, 2+i+numMeta)}, ints.slice(0, 2+i+numMeta)]
|
||||
}
|
||||
|
||||
function nodeValue(node){
|
||||
var total = 0;
|
||||
if(node.children.length){
|
||||
return node.meta.map(a=>(a-1)).map(a=>(node.children[a])).filter(a=>(a)).map(n=>(nodeValue(n))).reduce((a,b)=>(a+b), 0);
|
||||
}
|
||||
else{
|
||||
return node.meta.reduce((a,b)=>(a+b));
|
||||
}
|
||||
}
|
||||
|
||||
console.log(nodeValue(parseTree(nums)[0]));
|
Reference in New Issue
Block a user