aboutsummaryrefslogtreecommitdiff
path: root/2025/05/puzzle-2.awk
blob: 3dfc6612097772cb94c5faf1787afdaee3ab26e1 (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
#!/usr/bin/gawk -f

function rangecmp(i1, v1, i2, v2)
{
	return v1[1] - v2[1]
}

function max(x, y)
{
	return x > y ? x : y
}

BEGIN { FS = "-" }

NF == 2 {
	xs[NR][1] = $1
	xs[NR][2] = $2
}

END {
	asort(xs, xs, "rangecmp")
	for (i in xs) {
		if (xs[i][2] <= m)
			continue
		cnt += xs[i][2] - max(xs[i][1], m)
		if (xs[i][1] > m)
			cnt++
		m = xs[i][2]
	}
	print cnt
}