发布于 2016-01-26 23:24:12 | 146 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的GO语言教程,程序狗速度看过来!

Go语言

Go是一种新的语言,一种并发的、带垃圾回收的、快速编译的语言。Go是谷歌2009年发布的第二款编程语言。2009年7月份,谷歌曾发布了Simple语言,它是用来开发Android应用的一种BASIC语言。


这篇文章主要介绍了Go语言算法之寻找数组第二大元素的方法,以实例形式分析了不排序、只循环一次来实现寻找数组第二大元素的技巧,是比较典型的算法,需要的朋友可以参考下

本文实例讲述了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语言程序设计有所帮助。



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务