update euler 206

This commit is contained in:
VicRen
2021-01-06 08:47:13 +08:00
parent dbde6b107d
commit 9383aba292
2 changed files with 73 additions and 3 deletions

View File

@@ -4,6 +4,7 @@ import (
"fmt" "fmt"
"math" "math"
"math/big" "math/big"
"time"
) )
func main() { func main() {
@@ -11,20 +12,34 @@ func main() {
} }
func solution() { func solution() {
ts := time.Now()
n := math.Sqrt(19293949596979899) n := math.Sqrt(19293949596979899)
t := math.Sqrt(10203040506070809) t := math.Sqrt(10203040506070809)
for i := n; i >= t; i-- { for i := n; i >= t; i-- {
if i == 1389019170 {
fmt.Println(i)
}
x := (&big.Int{}).SetInt64(int64(i)) x := (&big.Int{}).SetInt64(int64(i))
if !isEndsWith37(x.String()) {
continue
}
if isMatch(x.Mul(x, x)) { if isMatch(x.Mul(x, x)) {
fmt.Println(x) fmt.Println(x)
fmt.Println("num is", int64(i)*10) 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 { func isMatch(i *big.Int) bool {
x := i.String() x := i.String()
num := x[0] num := x[0]

View File

@@ -7,6 +7,7 @@ import (
func Test_isMatch(t *testing.T) { func Test_isMatch(t *testing.T) {
fn, _ := (&big.Int{}).SetString("10203040506070809", 0) fn, _ := (&big.Int{}).SetString("10203040506070809", 0)
fn2, _ := (&big.Int{}).SetString("10203040506070808", 0)
type args struct { type args struct {
i *big.Int i *big.Int
} }
@@ -22,6 +23,13 @@ func Test_isMatch(t *testing.T) {
}, },
true, true,
}, },
{
"test2",
args{
fn2,
},
false,
},
} }
for _, tt := range tests { for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) { t.Run(tt.name, func(t *testing.T) {
@@ -31,3 +39,50 @@ func Test_isMatch(t *testing.T) {
}) })
} }
} }
func Test_isEndsWith37(t *testing.T) {
type args struct {
s string
}
tests := []struct {
name string
args args
want bool
}{
{
"test1",
args{
"123",
},
true,
},
{
"test2",
args{
"127",
},
true,
},
{
"test3",
args{
"12",
},
false,
},
{
"test4",
args{
"",
},
false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := isEndsWith37(tt.args.s); got != tt.want {
t.Errorf("isEndsWith37() = %v, want %v", got, tt.want)
}
})
}
}