code.go 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package main
  2. import (
  3. "fmt"
  4. "io/ioutil"
  5. "log"
  6. "os"
  7. "strconv"
  8. "strings"
  9. )
  10. func readInput(file string) []string {
  11. content, err := ioutil.ReadFile(file)
  12. if err != nil {
  13. log.Fatal(err)
  14. }
  15. lines := strings.Split(string(content), "\n")
  16. return lines
  17. }
  18. func part1(lines []string) int64 {
  19. var gamma []string
  20. var epsilon []string
  21. for i := 0; i < len(lines[0]); i++ {
  22. counts := []int{0, 0}
  23. for _, line := range lines {
  24. if line[i] == '0' {
  25. counts[0]++
  26. } else {
  27. counts[1]++
  28. }
  29. }
  30. if counts[0] > counts[1] {
  31. gamma = append(gamma, "0")
  32. epsilon = append(epsilon, "1")
  33. } else {
  34. gamma = append(gamma, "1")
  35. epsilon = append(epsilon, "0")
  36. }
  37. }
  38. gammaNumber, err := strconv.ParseInt(strings.Join(gamma, ""), 2, 64)
  39. if err != nil {
  40. log.Fatal(err)
  41. }
  42. epsilonNumber, err := strconv.ParseInt(strings.Join(epsilon, ""), 2, 64)
  43. if err != nil {
  44. log.Fatal(err)
  45. }
  46. return gammaNumber * epsilonNumber
  47. }
  48. func main() {
  49. if len(os.Args) < 2 {
  50. log.Fatal("You need to provide path to input file!")
  51. }
  52. lines := readInput(os.Args[1])
  53. fmt.Println(part1(lines))
  54. }