package main
import (
"fmt"
"math/rand"
"time"
)
/*
1. 随机生成10个整数1-100的范围保存到数组,并从小到大顺叙打印以及求平均值、求最大值、和最大值下标、并查找是否包含55
*/
func randArr(arr1 [10]int) (arr [10]int) {
rand.Seed(time.Now().UnixNano())
for i := 0; i <= len(arr1) -1 ;i++ {
arr1[i] += rand.Intn(100)
}
return arr1
}
func BubbleSort(arr *[10]int) (maxVal int,maxIndex int) {
temp := 0
for i := 0; i < len(arr) -1; i++{
for j := 0; j < len(arr) -1 -i; j++{
if (*arr)[j] > (*arr)[j + 1]{
temp = (*arr)[j]
(*arr)[j] = (*arr)[j + 1]
(*arr)[j + 1] = temp
}
}
}
maxVal = arr[0]
maxIndex = 0
for i,_ := range arr{
if maxVal < (*arr)[i] {
maxVal = (*arr)[i]
maxIndex = i
}
}
return maxVal,maxIndex
}
func avgArr(arr [10]int) (avgNum float64) {
sum := 0.0
for _,v := range arr {
sum += float64(v)
}
avgNum = sum / float64(len(arr))
return avgNum
}
func BinaryFind(arr *[10]int,leftIndex int,rightIndex int,findVal int) {
if leftIndex > rightIndex{
fmt.Printf("\n数组中不包含%v\n",findVal)
return
}
middle := (leftIndex + rightIndex) / 2
if (*arr)[middle] > findVal{
BinaryFind(arr,leftIndex,middle -1,findVal)
} else if (*arr)[middle] < findVal {
BinaryFind(arr,middle + 1,rightIndex,findVal)
} else {
fmt.Printf("\n%v找到了下标为%v",findVal,middle)
}
}
func main() {
var arr [10]int
arr = randArr(arr)
maxVal,maxIndex := BubbleSort(&arr)
fmt.Println(arr)
avgNum := avgArr(arr)
fmt.Printf("arr数组平均值为%v 最大值为%v 最大值下标%v",avgNum,maxVal,maxIndex)
BinaryFind(&arr,0,len(arr) -1,90)
}
Golang 随机生成10个整数1-100的范围保存到数组,并倒叙打印以及求平均值、求最大值、和最大值下标、并查找是否包含55
于 2022-08-14 22:52:09 首次发布