36: double-base palindromes

This commit is contained in:
VicRen
2020-11-06 11:12:16 +08:00
parent b916d0d874
commit 3b69ef2618
2 changed files with 173 additions and 0 deletions

View File

@@ -0,0 +1,42 @@
package main
import (
"fmt"
"strconv"
"strings"
)
func main() {
sum := 0
for i := 0; i < 1e6; i++ {
if isPalindromeDecimal(i) && isPalindromeString(convertToBinary(i)) {
sum += i
}
}
fmt.Println("sum:", sum)
}
func isPalindromeDecimal(n int) bool {
return isPalindromeString(strconv.Itoa(n))
}
func convertToBinary(num int) string {
s := ""
if num == 0 {
return "0"
}
for ; num > 0; num /= 2 {
lsb := num % 2
s = strconv.Itoa(lsb) + s
}
return s
}
func isPalindromeString(s string) bool {
pb := strings.Builder{}
for i := len(s); i > 0; i-- {
pb.WriteString(s[i-1 : i])
}
pstr := pb.String()
return s == pstr
}

View File

@@ -0,0 +1,131 @@
package main
import (
"testing"
)
func Test_isPalindrome(t *testing.T) {
tt := []struct {
name string
input int
want bool
}{
{
"1",
1,
true,
},
{
"11",
11,
true,
},
{
"1001",
1001,
true,
},
{
"123456654321",
123456654321,
true,
},
{
"123456754321",
123456754321,
false,
},
}
for _, tc := range tt {
t.Run(tc.name, func(t *testing.T) {
got := isPalindromeDecimal(tc.input)
if got != tc.want {
t.Errorf("IsPalindrome(%d)=%v, want %v", tc.input, got, tc.want)
}
})
}
}
func Test_isPalindromeString(t *testing.T) {
type args struct {
s string
}
tests := []struct {
name string
args args
want bool
}{
{
"1",
args{"1"},
true,
},
{
"11",
args{"11"},
true,
},
{
"1001",
args{"1001"},
true,
},
{
"123456654321",
args{"123456654321"},
true,
},
{
"123456754321",
args{"123456754321"},
false,
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := isPalindromeString(tt.args.s); got != tt.want {
t.Errorf("isPalindromeString() = %v, want %v", got, tt.want)
}
})
}
}
func Test_convertToBinary(t *testing.T) {
type args struct {
num int
}
tests := []struct {
name string
args args
want string
}{
{
"1",
args{1},
"1",
},
{
"2",
args{2},
"10",
},
{
"3",
args{3},
"11",
},
{
"7",
args{7},
"111",
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := convertToBinary(tt.args.num); got != tt.want {
t.Errorf("convertToBinary() = %v, want %v", got, tt.want)
}
})
}
}