Files
codekata-golang/206_concealed_square/main.go
2021-01-06 08:47:13 +08:00

55 lines
770 B
Go

package main
import (
"fmt"
"math"
"math/big"
"time"
)
func main() {
solution()
}
func solution() {
ts := time.Now()
n := math.Sqrt(19293949596979899)
t := math.Sqrt(10203040506070809)
for i := n; i >= t; i-- {
x := (&big.Int{}).SetInt64(int64(i))
if !isEndsWith37(x.String()) {
continue
}
if isMatch(x.Mul(x, x)) {
fmt.Println(x)
fmt.Println("num is", int64(i)*10)
fmt.Println(time.Since(ts))
break
}
}
}
func isEndsWith37(s string) bool {
if len(s) == 0 {
return false
}
c := s[len(s)-1]
if c == '3' || c == '7' {
return true
}
return false
}
func isMatch(i *big.Int) bool {
x := i.String()
num := x[0]
for i := 2; i < len(x); i += 2 {
if x[i] == num+1 {
num++
continue
}
return false
}
return true
}