part1.go 888 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package main
  2. import (
  3. "fmt"
  4. "log"
  5. "os"
  6. "strings"
  7. "strconv"
  8. )
  9. func main(){
  10. var dial int = 50
  11. var cnt int = 0
  12. content, err := os.ReadFile("input.txt")
  13. if err != nil {
  14. log.Fatal(err)
  15. }
  16. lines := strings.Split(string(content),"\n")
  17. for index, itr := range(lines){
  18. fmt.Printf("%v %v\n",index,itr)
  19. if itr == ""{
  20. break
  21. }
  22. if string(itr[0]) == "L" {
  23. tmp, err := strconv.Atoi(itr[1:])
  24. if err != nil {
  25. log.Fatal(err)
  26. }
  27. dial = dial - tmp
  28. }else{
  29. tmp, err := strconv.Atoi(itr[1:])
  30. if err != nil {
  31. log.Fatal(err)
  32. }
  33. dial = dial + tmp
  34. }
  35. fmt.Printf("Dial before adjust: %v\n",dial)
  36. for dial >= 100{
  37. dial = dial - 100
  38. }
  39. for dial < 0 {
  40. dial = dial + 100
  41. }
  42. fmt.Printf("Dial after adjust: %v\n",dial)
  43. if dial == 0 {
  44. cnt++
  45. }
  46. }
  47. fmt.Printf("res cnt: %v",cnt)
  48. }