summary refs log tree commit diff homepage
path: root/2018/day08.c
blob: 7357ed8babf29779f18e70a72e0e9a845dc7b2c2 (plain) (blame)
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
#include <stdio.h>
#include <stdlib.h>

typedef unsigned uint;

static uint sum;

static uint meta(void) {
	uint meta;
	scanf("%u", &meta);
	sum += meta;
	return meta;
}

static uint node(void) {
	uint nchild, nmeta;
	scanf("%u %u", &nchild, &nmeta);
	uint children[nchild];
	uint metas[nmeta];
	for (uint i = 0; i < nchild; ++i) {
		children[i] = node();
	}
	for (uint i = 0; i < nmeta; ++i) {
		metas[i] = meta();
	}
	uint val = 0;
	if (nchild) {
		for (uint i = 0; i < nmeta; ++i) {
			if (!metas[i] || metas[i] > nchild) continue;
			val += children[metas[i] - 1];
		}
	} else {
		for (uint i = 0; i < nmeta; ++i) {
			val += metas[i];
		}
	}
	return val;
}

int main() {
	uint val = node();
	printf("%u\n", sum);
	printf("%u\n", val);
}
t/bin/man1/bit.1?id=fb34d727d81485248be40d5282ae0295636018f4&follow=1'>Simplify and build bitJune McEnroe lex is a waste of time. 2019-05-29Add xx -p optionJune McEnroe 2019-05-27Add FrontierJune McEnroe 2019-05-27Break nicks with ZWNJJune McEnroe This should prevent bad wrapping. 2019-05-26Add DawnJune McEnroe 2019-05-20Declare vasprintf(3) for GNUJune McEnroe who the fuck is scraeming "#define _GNU_SOURCE" at my house. show yourself, coward. i will never #define _GNU_SOURCE 2019-05-20Fix comparison warning in ttpreJune McEnroe 2019-05-20Add AuthorityJune McEnroe 2019-05-19Specify precedence of unary versions of operatorsJune McEnroe 2019-05-18Add compound assignment operators to orderJune McEnroe 2019-05-15Support simple assignment in orderJune McEnroe 2019-05-15Implement sizeof in orderJune McEnroe 2019-05-15Add orderJune McEnroe 2019-05-12Add T suffix in bitJune McEnroe 2019-05-10Highlight yacc and lex files as CJune McEnroe Their %-prefixed directives should probably be highlighted Macro. 2019-05-10Use val instead of suboptargJune McEnroe suboptarg doesn't exist in GNU. Hopefully BSD getsubopt also sets val on failure? 2019-05-09Add Parable of the SowerJune McEnroe 2019-05-07Add bit without buildJune McEnroe Need to do some stuff in the Makefile for lex and yacc and generating HTML pages for it. 2019-05-04Fix MANDIR typoJune McEnroe 2019-05-04Move relay to binJune McEnroe