标签: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