Browse Source

Able to read monkeys

Piotr Czajkowski 1 year ago
parent
commit
1cd67ec090
1 changed files with 73 additions and 0 deletions
  1. 73 0
      21/code.go

+ 73 - 0
21/code.go

@@ -0,0 +1,73 @@
+package main
+
+import (
+	"bufio"
+	"fmt"
+	"log"
+	"os"
+	"strings"
+)
+
+type kind byte
+
+const (
+	op kind = iota
+	val
+)
+
+type monkey struct {
+	name  string
+	spec  kind
+	left  string
+	right string
+	op    byte
+	value int
+}
+
+func readInput(file *os.File) map[string]monkey {
+	scanner := bufio.NewScanner(file)
+	monkeys := make(map[string]monkey)
+
+	for scanner.Scan() {
+		line := scanner.Text()
+		if line == "" {
+			continue
+		}
+
+		var current monkey
+		if strings.ContainsAny(line, "+-/*") {
+			current.spec = op
+			n, err := fmt.Sscanf(line, "%s %s %c %s", &current.name, &current.left, &current.op, &current.right)
+			if n != 4 || err != nil {
+				log.Fatal("Can't parse (op): ", line, err)
+			}
+		} else {
+			current.spec = val
+			n, err := fmt.Sscanf(line, "%s %d", &current.name, &current.value)
+			if n != 2 || err != nil {
+				log.Fatal("Can't parse: ", line, err)
+			}
+		}
+
+		current.name = strings.TrimRight(current.name, ":")
+		monkeys[current.name] = current
+	}
+
+	return monkeys
+}
+
+func main() {
+	if len(os.Args) < 2 {
+		log.Fatal("You need to specify a file!")
+	}
+
+	filePath := os.Args[1]
+	file, err := os.Open(filePath)
+	if err != nil {
+		log.Fatalf("Failed to open %s!\n", filePath)
+
+	}
+
+	monkeys := readInput(file)
+	fmt.Println(monkeys)
+}