Go语言算法之寻找数组第二大元素的方法
本文实例讲述了Go语言算法之寻找数组第二大元素的方法。分享给大家供大家参考。具体如下:
该算法的原理是,在遍历数组的时,始终记录当前最大的元素和第二大的元素。示例代码如下:
packagedemo01
import(
"fmt"
)
funcNumberTestBase(){
fmt.Println("ThisisNumberTestBase")
nums:=[]int{12,24,2,5,13,8,7}
fmt.Println("nums:",nums)
secondMax:=getSecondMaxNum(nums)
fmt.Println("secondMax=",secondMax)
}
funcgetSecondMaxNum(nums[]int)int{
length:=len(nums)
iflength==0{
panic("Slicenumscannotbe0-size.")
}
iflength==1{
returnnums[0]
}
varmax,secondMaxint
ifnums[0]>nums[1]{
max=nums[0]
secondMax=nums[1]
}else{
max=nums[1]
secondMax=nums[0]
}
fori:=2;i<len(nums);i++{
ifnums[i]>secondMax{
ifnums[i]<=max{
secondMax=nums[i]
}else{
secondMax,max=max,nums[i]
}
}
}
returnsecondMax
}
希望本文所述对大家的Go语言程序设计有所帮助。
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语