aoc24/solutions/01.ts

42 lines
1.5 KiB
TypeScript
Raw Permalink Normal View History

2024-12-04 22:27:23 +01:00
import { solvables } from "../main.ts";
import type { Solvable } from "../solvable.ts";
import { readInput } from "../utils.ts";
class DayOne implements Solvable {
input = readInput('01')
2024-12-08 00:46:45 +01:00
public part1(): Promise<DayOne> {
2024-12-04 23:15:42 +01:00
const vals = this.input
.split("\n")
.map(line => line.split(' ').map(col => Number.parseInt(col)))
const left = vals.map(line => line[0]).sort()
2024-12-04 23:15:42 +01:00
const right = vals.map(line => line[1]).sort()
2024-12-04 22:27:23 +01:00
const diff: number[] = []
left.forEach((left, idx) => {
diff.push(Math.abs(left - right[idx]))
})
2024-12-04 22:27:23 +01:00
const result = diff.reduce((prev, curr) => prev + curr)
console.log(result)
2024-12-08 00:46:45 +01:00
return new Promise(() => this)
2024-12-04 22:27:23 +01:00
}
2024-12-08 00:46:45 +01:00
public part2(): Promise<DayOne> {
const vals = this.input.trim().split("\n").map(line => line.split(' '))
const left = vals.map(line => Number.parseInt(line[0])).sort()
const right = vals.map(line => Number.parseInt(line[1])).sort()
const countedOccurences: Map<number, number> = new Map()
left.forEach(left_val => countedOccurences.set(left_val, right.filter(right_val => left_val === right_val).length))
const result = countedOccurences
.entries()
.map(([left_val, occurences]) => left_val * occurences)
.reduce((prev, curr) => prev + curr)
console.log(result)
2024-12-08 00:46:45 +01:00
return new Promise(() => this)
2024-12-04 22:27:23 +01:00
}
}
solvables.push(new DayOne())