标签:range 中文 范围 inf 文字 print 回文 net imp
1.编写程序,在终端输出九九乘法表。
package main
import (
"fmt"
)
func main() {
for i := 1; i <= 9; i++ {
for j := 1; j <= i; j++ {
fmt.Printf("%d*%d=%d%s", j, i, i*j, "\t")
}
fmt.Printf("%s", "\n")
}
}

2.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如 1x6=6 2X3=6 1+2+3=6 1*28=28 2*14=28 4*7=28 1+2+4+7+14=28。编程找出1000以内的所有完数。
思路:先求因子数,所有和n去余等于0的为该数的因子。 因子相加等于n的为完数
package main
import (
"fmt"
)
func calc(n int) bool {
var sum int
for i := 1; i < n; i++ {
if n%i == 0 {
sum += i
}
}
return n == sum
}
func wanshu(n int) {
for j := 1; j <= n; j++ {
if calc(j) {
fmt.Println(j)
}
}
}
func main() {
var a int
fmt.Scanf("%d", &a)
wanshu(a)
}

3.输入一个字符串,判断其是否为回文。回文字符串是指从左到右读和从右到左读完全相同的字符串。
思路
1 判断回文需要比较 str[0]与 str[len-1] str[1] str[len-1-1]......是否相同
2 判断不超过该字符串的长度的一半
3 在go语言中需要判断中文和英文所占用的字符数
golang byte rune区别参考:https://blog.csdn.net/HaoDaWang/article/details/79971395
package main
import (
"fmt"
)
func judge(str string) bool {
s := []rune(str)
for key, _ := range s {
if key == int(len(s)/2) {
break
}
last := len(s) - key - 1
if s[key] != s[last] {
return false
}
}
// for n := 0; n < len(str); n++ {
// if n == int(len(str)/2) {
// break
// }
// last := len(str) - n - 1
// if str[n] != str[last] {
// return false
// }
// }
return true
}
func main() {
var str1 string
fmt.Scanf("%s", &str1)
result := judge(str1)
if result {
fmt.Println("完数")
} else {
fmt.Println("不是完数")
}
}

4.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
5.计算两个大数相加的和,这两个大数会超过int64的表示范围
标签:range 中文 范围 inf 文字 print 回文 net imp
原文地址:https://www.cnblogs.com/LC161616/p/9788936.html