123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- package main
- import (
- "bufio"
- "fmt"
- "log"
- "os"
- "slices"
- "strings"
- )
- func readInput(file *os.File) map[string][]string {
- scanner := bufio.NewScanner(file)
- computers := make(map[string][]string)
- for scanner.Scan() {
- line := scanner.Text()
- if line == "" {
- break
- }
- parts := strings.Split(line, "-")
- if len(parts) != 2 {
- log.Fatalf("Bad input: %s", line)
- }
- computers[parts[0]] = append(computers[parts[0]], parts[1])
- computers[parts[1]] = append(computers[parts[1]], parts[0])
- }
- return computers
- }
- func getSets(computers map[string][]string) [][]string {
- var sets [][]string
- for key, value := range computers {
- if key[0] != 't' {
- continue
- }
- for i := range value {
- for _, subKey := range computers[value[i]] {
- if subKey == key {
- continue
- }
- subValues := computers[subKey]
- for j := range subValues {
- if subValues[j] == key {
- sets = append(sets, []string{key, value[i], subKey})
- }
- }
- }
- }
- }
- return sets
- }
- func part1(computers map[string][]string) int {
- sets := getSets(computers)
- for i := range sets {
- slices.Sort(sets[i])
- }
- unique := make(map[string]bool)
- for i := range sets {
- unique[strings.Join(sets[i], ",")] = true
- }
- return len(unique)
- }
- func contains(nodes []string, connections map[string]bool) bool {
- if len(connections) == 0 {
- return true
- }
- for key, _ := range connections {
- var isThere bool
- for i := range nodes {
- if nodes[i] == key {
- isThere = true
- break
- }
- }
- if !isThere {
- return false
- }
- }
- return true
- }
- func connected(key string, computers map[string][]string, connections map[string]bool) {
- if !contains(computers[key], connections) {
- return
- }
- connections[key] = true
- for _, value := range computers[key] {
- if connections[value] {
- continue
- }
- connected(value, computers, connections)
- }
- }
- func part2(computers map[string][]string) string {
- var allConnections []map[string]bool
- for key, _ := range computers {
- connections := make(map[string]bool)
- connected(key, computers, connections)
- allConnections = append(allConnections, connections)
- }
- var biggest int
- var connections map[string]bool
- for i := range allConnections {
- if len(allConnections[i]) > biggest {
- biggest = len(allConnections[i])
- connections = allConnections[i]
- }
- }
- var keys []string
- for key, _ := range connections {
- keys = append(keys, key)
- }
- slices.Sort(keys)
- return strings.Join(keys, ",")
- }
- 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)
- }
- computers := readInput(file)
- fmt.Println("Part1:", part1(computers))
- fmt.Println("Part2:", part2(computers))
- }
|