本文实例讲述了go语言算法之寻找数组第二大元素的方法。分享给大家供大家参考。具体如下:

算法的原理是,在遍历数组的时,始终记录当前最大的元素和第二大的元素。示例代码如下:

复制代码 代码如下: package demo01 

 

import ( 

    “fmt” 



 

func NumberTestBase() { 

    fmt.Println(“This is NumberTestBase”) 

 

    nums := []int{12, 24, 2, 5, 13, 8, 7} 

    fmt.Println(“nums:”, nums) 

    secondMax := getSecondMaxNum(nums) 

    fmt.Println(“secondMax=”, secondMax) 



 

func getSecondMaxNum(nums []int) int { 

    length := len(nums) 

    if length == 0 { 

        panic(“Slice nums cannot be 0-size.”) 

    } 

 

    if length == 1 { 

        return nums[0] 

    } 

 

    var max, secondMax int 

    if nums[0] > nums[1] { 

        max = nums[0] 

        secondMax = nums[1] 

    } else { 

        max = nums[1] 

        secondMax = nums[0] 

    } 

 

    for i := 2; i < len(nums); i++ { 

        if nums[i] > secondMax { 

            if nums[i] <= max { 

                secondMax = nums[i] 

            } else { 

                secondMax, max = max, nums[i] 

            } 

        } 

    } 

    return secondMax 

}

希望本文所述对大家的Go语言程序设计有所帮助。

声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。