projecteuler-go/pe26/pe26.go

82 lines
1.2 KiB
Go
Raw Normal View History

2021-06-05 05:05:13 +00:00
package pe26
import (
2021-06-05 20:48:09 +00:00
"fmt"
"strconv"
2021-06-05 05:05:13 +00:00
)
func max(arr []int) int {
2021-06-05 20:48:09 +00:00
result := 0
for v := range arr {
if v > result {
result = v
}
}
return result
2021-06-05 05:05:13 +00:00
}
func get_next_digit(numerator, denominator int) int {
2021-06-05 20:48:09 +00:00
if numerator < denominator {
numerator *= 10
}
remainder := numerator % denominator
return remainder
2021-06-05 05:05:13 +00:00
}
func calc_digit_repeat(i int, c chan int) {
2021-06-05 20:48:09 +00:00
digit_length := map[int]int{
0: 0, 1: 0, 2: 0, 3: 0, 4: 0,
5: 0, 6: 0, 7: 0, 8: 0, 9: 0,
}
rem := 1
for {
rem = get_next_digit(rem, i)
if rem == 0 {
// no repeats
c <- 0
break
}
if digit_length[rem] > 0 {
// found a repeat
c <- digit_length[rem]
break
} else {
// new digit
// increment other non-zero digits
for k, v := range digit_length {
if v > 0 {
digit_length[k]++
}
}
digit_length[rem]++
}
}
2021-06-05 05:05:13 +00:00
}
2021-06-05 20:48:09 +00:00
func start_calc_digit_repeat(i int) chan int {
c := make(chan int)
2021-06-05 05:05:13 +00:00
2021-06-05 20:48:09 +00:00
go calc_digit_repeat(i, c)
2021-06-05 05:05:13 +00:00
2021-06-05 20:48:09 +00:00
return c
2021-06-05 05:05:13 +00:00
}
func Solve(args []string) {
2021-06-05 20:48:09 +00:00
N, _ := strconv.Atoi(args[0])
2021-06-05 05:05:13 +00:00
2021-06-05 20:48:09 +00:00
chan_list := make([]chan int, N)
2021-06-05 05:05:13 +00:00
2021-06-05 20:48:09 +00:00
for i := 1; i <= N; i++ {
chan_list[i-1] = start_calc_digit_repeat(i)
}
2021-06-05 05:05:13 +00:00
2021-06-05 20:48:09 +00:00
max, max_idx := 0, 1
for i := 0; i < N; i++ {
val := <-chan_list[i]
if val > max {
max = val
max_idx = i + 1
}
}
fmt.Println(max_idx)
2021-06-05 05:05:13 +00:00
}