code.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package main
  2. import (
  3. "bufio"
  4. "fmt"
  5. "log"
  6. "os"
  7. )
  8. func readInput(file *os.File) []int {
  9. scanner := bufio.NewScanner(file)
  10. var numbers []int
  11. for scanner.Scan() {
  12. line := scanner.Text()
  13. if line == "" {
  14. continue
  15. }
  16. var current int
  17. n, err := fmt.Sscanf(line, "%d", &current)
  18. if n != 1 || err != nil {
  19. log.Fatal("Can't parse:", line, err)
  20. }
  21. numbers = append(numbers, current)
  22. }
  23. return numbers
  24. }
  25. func indexOf(numbers []int, number int) int {
  26. for i := range numbers {
  27. if numbers[i] == number {
  28. return i
  29. }
  30. }
  31. return -1
  32. }
  33. func establishNewIndex(size int, current int, value int) int {
  34. delta := current + value
  35. if delta < 0 {
  36. delta = 0 - delta
  37. rest := delta % size
  38. return size - 1 - rest
  39. }
  40. return delta % size
  41. }
  42. func mix(numbers []int) []int {
  43. size := len(numbers)
  44. mixed := make([]int, size)
  45. copy(mixed, numbers)
  46. for i := range numbers {
  47. currentIndex := indexOf(mixed, numbers[i])
  48. newIndex := establishNewIndex(size, i, numbers[i])
  49. fmt.Println(currentIndex, newIndex, numbers[i])
  50. }
  51. return mixed
  52. }
  53. func main() {
  54. if len(os.Args) < 2 {
  55. log.Fatal("You need to specify a file!")
  56. }
  57. filePath := os.Args[1]
  58. file, err := os.Open(filePath)
  59. if err != nil {
  60. log.Fatalf("Failed to open %s!\n", filePath)
  61. }
  62. numbers := readInput(file)
  63. fmt.Println(mix(numbers))
  64. }