国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > Golang > 正文

Go語(yǔ)言算法之尋找數(shù)組第二大元素的方法

2020-04-01 19:21:38
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這篇文章主要介紹了Go語(yǔ)言算法之尋找數(shù)組第二大元素的方法,以實(shí)例形式分析了不排序、只循環(huán)一次來(lái)實(shí)現(xiàn)尋找數(shù)組第二大元素的技巧,是比較典型的算法,需要的朋友可以參考下
 

本文實(shí)例講述了Go語(yǔ)言算法之尋找數(shù)組第二大元素的方法。分享給大家供大家參考。具體如下:

該算法的原理是,在遍歷數(shù)組的時(shí),始終記錄當(dāng)前最大的元素和第二大的元素。示例代碼如下:

 

復(fù)制代碼代碼如下:
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  
}

 

希望本文所述對(duì)大家的Go語(yǔ)言程序設(shè)計(jì)有所幫助。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 焦作市| 巢湖市| 泸州市| 黄大仙区| 台中市| 冷水江市| 宜丰县| 阿克苏市| 嘉荫县| 盘山县| 乡宁县| 庆元县| 宝兴县| 和平县| 伊川县| 洞头县| 山丹县| 马龙县| 海口市| 永嘉县| 金阳县| 海安县| 镇巴县| 连城县| 石家庄市| 大新县| 视频| 当涂县| 五大连池市| 克东县| 仁化县| 澄迈县| 新巴尔虎左旗| 南阳市| 永丰县| 天柱县| 河北区| 遂昌县| 利辛县| 凤阳县| 沙洋县|