@(go语言 黑马)[GO语言]
统计各字母的个数
- 题目:输入一串字母,统计各个字母输入的个数
- 逻辑:该案例统计字母上限由数组长度决定,可自行设置
- 代码如下:
package main
import "fmt"
func main() {
fmt.Println("请输入一串字母,以回车结束")
var array [20]byte
for i := 0; i < len(array); i++ {
fmt.Scanf("%c", &array[i]) //把输入的每个字母记录在切片array中
}
var ch [26]int //26个数字分别对应26个字母,用来统计各字母出现的次数
for i := 0; i < len(array); i++ {
ch[array[i]-'a']++
//array中的每个字母减去a,刚好在0到25之间,共26个数,每个下标对应一个字母
//在Assic码表中,每个字符对应一个数字,并且a-z是按照顺序排列,所以可以得到上面的效果
}
for i := 0; i < len(ch); i++ {
if ch[i] > 0 { //出现了该字母就打印,没有出现则不打印
fmt.Printf("%c出现了%d次\n", i+'a', ch[i])
}
}
}
找出一串数字中最大值的位置
- 题目:找出一串数字中最大值的位置
- 逻辑:逻辑在注释中
- 代码如下:
package main
import "fmt"
func main() { //求出切片中最大数的位置
var a, b int
fmt.Println("请输入数组长度:")
fmt.Scan(&a)
fmt.Println("请输入数组元素:")//这里输入要用空格隔开,并且数量不能小于a的长度
arr := make([]int, a)
for i := 0; i < len(arr); i++ {
fmt.Scan(&b)
arr[i] = b
}
fmt.Println(arr)
//找出最大数,并且不改变其位置,并记录它的位置
var index int //记录下标
temp := arr[0] //引入变量,用来与所有元素比较
for i := 0; i < a; i++ {
if arr[i] > temp {
temp = arr[i] //使temp等于比他大的元素
index = i //记录每次满足条件的元素下标,最后一个就是最大元素的下标
}
}
fmt.Printf("最大数为arr[%d]=%d", index, arr[index])
}
求自守数
- 题目:a的平方的末尾几位数等于a,那么a为自守数
- 逻辑:位数不同的数字分开处理
- 代码如下:
package main
import "fmt"
func main() {
//a的平方的末尾几位数等于a,那么a为自守数
var num [10001]int
for i := 0; i <= 10000; i++ {//通过这个循环,0-10000就储存在切片中了
num[i] = i
}
for i := 0; i <= 10000; i++ {
if num[i] < 10 {
if num[i]*num[i]%10 == num[i] {//平方后,求出个位数
fmt.Printf("num[%d]=%d是自守数\n", i, num[i])
}
}
if 9 < num[i] && num[i] < 100 {
if num[i]*num[i]%100 == num[i] {
fmt.Printf("num[%d]=%d是自守数\n", i, num[i])
}
}
if 99 < num[i] && num[i] < 1000 {
if num[i]*num[i]%1000 == num[i] {
fmt.Printf("num[%d]=%d是自守数\n", i, num[i])
}
}
if 990 < num[i] && num[i] <= 10000 {
if num[i]*num[i]%10000 == num[i] {
fmt.Printf("num[%d]=%d是自守数\n", i, num[i])
}
}
}
}