mirror of
https://github.com/seigler/aoc2024
synced 2025-07-26 00:36:10 +00:00
day 7 tidier
This commit is contained in:
parent
74e3e285b5
commit
433321cd50
2 changed files with 12 additions and 29 deletions
|
@ -96,13 +96,13 @@
|
|||
"solved": true,
|
||||
"result": "12553187650171",
|
||||
"attempts": [],
|
||||
"time": 21.47319
|
||||
"time": 23.011534
|
||||
},
|
||||
"part2": {
|
||||
"solved": true,
|
||||
"result": "96779702119491",
|
||||
"attempts": [],
|
||||
"time": 782.404856
|
||||
"time": 599.068573
|
||||
}
|
||||
},
|
||||
{
|
||||
|
|
|
@ -3,18 +3,13 @@ import run from "aocrunner"
|
|||
const parseInput = (rawInput: string) =>
|
||||
rawInput.split("\n").map((line) => line.split(/[: ]+/).map(Number))
|
||||
|
||||
const part1 = (rawInput: string) => {
|
||||
const input = parseInput(rawInput)
|
||||
|
||||
const solve = (rawInput: string, isP2?: boolean) => {
|
||||
const input = rawInput.split('\n').map(l => l.split(/[^\d]+/).map(Number))
|
||||
return input.reduce((total, [target, ...values]) => {
|
||||
const operators = [(a,b) => a * b, (a,b) => a + b]
|
||||
const operators = [(a,b) => a * b, (a,b) => a + b, ...(isP2 ? [(a,b) => Number(`${a}${b}`)] : [])]
|
||||
const evaluate = (numbers: number[]) => {
|
||||
if (numbers[0] > target) {
|
||||
return false
|
||||
}
|
||||
if (numbers.length === 1) {
|
||||
return numbers[0] === target
|
||||
}
|
||||
if (numbers[0] > target) return false
|
||||
if (numbers.length === 1) return numbers[0] === target
|
||||
for (const op of operators) {
|
||||
if (evaluate([op(numbers[0], numbers[1]), ...numbers.slice(2)])) { return true }
|
||||
}
|
||||
|
@ -23,24 +18,12 @@ const part1 = (rawInput: string) => {
|
|||
}, 0)
|
||||
}
|
||||
|
||||
const part2 = (rawInput: string) => {
|
||||
const input = parseInput(rawInput)
|
||||
const part1 = (rawInput: string) => {
|
||||
return solve(rawInput, false)
|
||||
}
|
||||
|
||||
return input.reduce((total, [target, ...values]) => {
|
||||
const operators = [(a,b) => a * b, (a,b) => a + b, (a,b) => Number(`${a}${b}`)]
|
||||
const evaluate = (numbers: number[]) => {
|
||||
if (numbers[0] > target) {
|
||||
return false
|
||||
}
|
||||
if (numbers.length === 1) {
|
||||
return numbers[0] === target
|
||||
}
|
||||
for (const op of operators) {
|
||||
if (evaluate([op(numbers[0], numbers[1]), ...numbers.slice(2)])) { return true }
|
||||
}
|
||||
}
|
||||
return total + (evaluate(values) ? target : 0)
|
||||
}, 0)
|
||||
const part2 = (rawInput: string) => {
|
||||
return solve(rawInput, true)
|
||||
}
|
||||
|
||||
run({
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue