AoC/2020/day9/main.swift

46 lines
927 B
Swift
Raw Permalink Normal View History

2020-12-11 22:25:14 +01:00
import Foundation
let input = loadData(day: 9)
let scanner = Scanner(string: input)
let numbers = scanner.integers()
2020-12-11 22:25:14 +01:00
var weakness: Int? = nil
outer: for i in 25..<numbers.count {
let search = numbers[i]
for j in (i - 25)..<i {
for k in j..<i {
if search == numbers[j] + numbers[k] {
continue outer
}
}
}
print("first which is not sum", i, search)
weakness = search
break
}
guard let weakness = weakness else { fatalError("No weakness found") }
outer: for i in 0..<numbers.count {
var sum = 0
var min = Int.max
var max = Int.min
for j in (i+1)..<numbers.count {
let n = numbers[j]
sum += n
if n < min { min = n }
if n > max { max = n }
if sum == weakness {
print(min + max)
break outer
}
if sum > weakness {
break
}
}
}