123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- package main
- import (
- "fmt"
- "io/ioutil"
- "log"
- "os"
- "strings"
- )
- var rounds map[int]int
- var numbersSpoken map[int][2]int
- func readFile(filePath string) {
- content, err := ioutil.ReadFile(filePath)
- if err != nil {
- log.Fatal(err)
- }
- for i, item := range strings.Split(string(content), ",") {
- var number int
- n, err := fmt.Sscanf(item, "%d", &number)
- if err != nil || n < 1 {
- log.Fatal(err)
- }
- rounds[i+1] = number
- numbersSpoken[number] = [2]int{i + 1, 0}
- }
- }
- func playGame(limit int) int {
- currentRound := len(rounds) + 1
- var currentNumber int
- for ; currentRound <= limit; currentRound++ {
- lastNumber := rounds[currentRound-1]
- if spoken, ok := numbersSpoken[lastNumber]; !ok {
- currentNumber = rounds[1]
- } else {
- if spoken[1] == 0 {
- currentNumber = rounds[1]
- } else {
- currentNumber = spoken[1] - spoken[0]
- }
- }
- rounds[currentRound] = currentNumber
- if _, ok := numbersSpoken[currentNumber]; !ok {
- numbersSpoken[currentNumber] = [2]int{currentRound, 0}
- } else {
- if numbersSpoken[currentNumber][1] == 0 {
- numbersSpoken[currentNumber] = [2]int{numbersSpoken[currentNumber][0], currentRound}
- } else {
- numbersSpoken[currentNumber] = [2]int{numbersSpoken[currentNumber][1], currentRound}
- }
- }
- }
- return currentNumber
- }
- func init() {
- rounds = make(map[int]int)
- numbersSpoken = make(map[int][2]int)
- }
- func main() {
- if len(os.Args) < 2 {
- log.Fatal("You need to specify a file!")
- }
- readFile(os.Args[1])
- fmt.Println(playGame(2020))
- }
|