-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathday15.rb
63 lines (49 loc) · 1.37 KB
/
day15.rb
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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
file = File.open("input/day15.txt", "r")
numbers = file.readlines[0].split(",").map{|x| x.to_i}
class Hash
def getOrInit(key)
# if number is not defined, initialize an array for it
if self.has_key?(key)
return self[key]
else
self[key] = []
return self[key]
end
end
end
currentRound = 0
prevNumber = ""
lastTimeSpoken = {}
while true
if currentRound < numbers.length
currentNumber = numbers[currentRound]
lastTimeSpoken.getOrInit(currentNumber).push(currentRound)
prevNumber = numbers[currentRound]
currentRound += 1
next
end
if lastTimeSpoken[prevNumber].length == 1
currentNumber = 0
lastTimeSpoken.getOrInit(0).push(currentRound)
else
lt1 = lastTimeSpoken[prevNumber][-1]
lt2 = lastTimeSpoken[prevNumber][-2]
currentNumber = lt1 - lt2
lastTimeSpoken.getOrInit(currentNumber).push(currentRound)
end
prevNumber = currentNumber
currentRound += 1
if currentRound == 2020
puts "Part 1: #{currentNumber}"
end
if currentRound == 30_000_000
puts "Part 2: #{currentNumber}"
end
# print some progress
#if currentRound % 1_000_000 == 0
# puts "Round: #{currentRound}, number: #{currentNumber}"
#end
if (currentRound > 30_000_000)
break
end
end