欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go語(yǔ)言排序算法之插入排序與生成隨機(jī)數(shù)詳解

 更新時(shí)間:2017年11月03日 08:44:33   作者:Corwien  
從這篇文章開(kāi)始將帶領(lǐng)大家學(xué)習(xí)Go語(yǔ)言的經(jīng)典排序算法,比如插入排序、選擇排序、冒泡排序、希爾排序、歸并排序、堆排序和快排,二分搜索,外部排序和MapReduce等,本文將先詳細(xì)介紹插入排序,并給大家分享了go語(yǔ)言生成隨機(jī)數(shù)的方法,下面來(lái)一起看看吧。

前言

排序,對(duì)于每種編程語(yǔ)言都是要面對(duì)的。這里跟大家一起分享golang實(shí)現(xiàn)一些排序算法,并且說(shuō)明如何生成隨機(jī)數(shù)。下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。

經(jīng)典排序算法

算法的學(xué)習(xí)非常重要,是檢驗(yàn)一個(gè)程序員水平的重要標(biāo)準(zhǔn)。學(xué)習(xí)算法不能死記硬背,需要理解其中的思想,這樣才能靈活應(yīng)用到實(shí)際的開(kāi)發(fā)中。

七大經(jīng)典排序算法

  • 插入排序
  • 選擇排序
  • 冒泡排序
  • 希爾排序
  • 歸并排序
  • 堆排序
  • 快速排序

插入排序

先考慮一個(gè)問(wèn)題:對(duì)于長(zhǎng)度為n的數(shù)組,前n-1位都是遞增有序的,如何排序?

     1.從第1位至第n-1位遍歷數(shù)組,發(fā)現(xiàn)第n位數(shù)字應(yīng)該放在第k位

     2.把第k位至第n-1位的數(shù)字依次向后挪一位

     3.這樣長(zhǎng)度為n的數(shù)組就是遞增有序的了

具體實(shí)現(xiàn)方法:

package main
import "fmt" 

func insertionSort(arr []int) {
  for i := 1; i < len(arr); i++ {
   value := arr[i]

   for j := i - 1; j >= 0; j-- {
    if value < arr[j] {
     arr[j+1], arr[j] = arr[j], value
    } else {
     break
    }

   }
  }

}

func main() {
 arr := []int{6, 5, 4, 3, 2, 1, 0}
 insertionSort(arr)

 fmt.Println("Sorted arr: ", arr)
}

復(fù)雜度:

時(shí)間復(fù)雜度:O(n*n)

空間復(fù)雜度:額外空間O(1)

O表達(dá)式(Big O notation)通常用來(lái)在計(jì)算機(jī)科學(xué)中表示算法的復(fù)雜度,包括:

時(shí)間復(fù)雜度:衡量算法的運(yùn)行時(shí)間

空間復(fù)雜度:衡量算法運(yùn)行所占的空間,比如內(nèi)存或硬盤等

一般情況下,O表達(dá)式代表的是最壞情況下的復(fù)雜度。

算法分析也是如此,在n個(gè)隨即數(shù)中查找某個(gè)數(shù)字,最好的情況是第一個(gè)數(shù)字就是,此時(shí)時(shí)間復(fù)雜度為O(1),若最后一個(gè)數(shù)字才是我們要找的,那么時(shí)間復(fù)雜度是O(n),這是最壞的情況。而平均運(yùn)行時(shí)間是從概率的角度看,若數(shù)字在每一個(gè)位置都可能出現(xiàn),則平均查找次數(shù)為n/2次。

平均運(yùn)行時(shí)間是所有情況中最有意義的,因?yàn)樗瞧谕倪\(yùn)行時(shí)間??涩F(xiàn)實(shí)中,平均運(yùn)行時(shí)間很難通過(guò)分析得到,一般都是通過(guò)運(yùn)行一定數(shù)量的實(shí)驗(yàn)數(shù)據(jù)后估算而來(lái)的。而最壞運(yùn)行時(shí)間是一種保證,那就是運(yùn)行時(shí)間不會(huì)再壞了。在應(yīng)用中,這是最重要的需求,通常,除非特別指定,我們提到的運(yùn)行時(shí)間都是最壞情況下的運(yùn)行時(shí)間。即,時(shí)間復(fù)雜度是最壞情況下的時(shí)間復(fù)雜度。

常見(jiàn)的算法時(shí)間復(fù)雜度由小到大依次為:

O(1)<O(log2n)<O(n)<O(n log2 n)<O(n^2)<O(n^3)<O(2^n)

這里的O就是一般表示復(fù)雜度的一個(gè)標(biāo)志,類似計(jì)算復(fù)雜度的函數(shù)名稱一樣。

兩種復(fù)雜度都是一種估算,

估算的方式就是根據(jù)代碼的邏輯,分析出對(duì)于復(fù)雜度的公式。

在時(shí)間復(fù)雜度上,主要記錄的是帶有變量的循環(huán)。

比如for (i = 0; i < n; i ++) {...}可理解為O(n)

而 x = n + 1; y = x + 1; z = x + y;雖然是三條語(yǔ)句,但是沒(méi)有循環(huán)操作,所以理解為O(1)

在空間復(fù)雜度上,主要記錄的是帶有變量的空間申請(qǐng)。

比如int[n] x;可以理解為O(n)

而 int x; int y; int z;雖然是三個(gè)變量,但是沒(méi)有變化的申請(qǐng)操作,所以理解為O(1)

大O符號(hào)是用于描述函數(shù)漸近行為的數(shù)學(xué)符號(hào)。既可以表示無(wú)窮大漸近也可以表示

無(wú)窮小漸近??茨闶怯迷谒惴ㄟ€是描述數(shù)學(xué)函數(shù)估計(jì)中的誤差項(xiàng)

再來(lái)看看我們的插入排序:

  • 當(dāng)數(shù)組是逆序的時(shí)候,時(shí)間復(fù)雜度是O(n*n)
  • 當(dāng)數(shù)組幾乎是有序的時(shí)候,時(shí)間復(fù)雜度是O(n)

另外插入排序的overhead特別小,可以理解為常數(shù)等于1

在實(shí)際應(yīng)用中,常數(shù)也是一個(gè)很重要的因素。有的算法復(fù)雜度低,但是常數(shù)較高;再加上數(shù)據(jù)的特點(diǎn),有時(shí)候反而比不上復(fù)雜度更高但是常數(shù)低的算法。

在理解插入排序算法的過(guò)程中,應(yīng)該要明白一個(gè)算法思想:

  • 把問(wèn)題分解為子問(wèn)題
  • 找到問(wèn)題的初始狀態(tài)
  • 從問(wèn)題的初始狀態(tài),通過(guò)子問(wèn)題,一步步得到最終的解

實(shí)際應(yīng)用中,要靈活的選擇算法,有幾個(gè)重點(diǎn)要考慮的:

  • 復(fù)雜度:包括時(shí)間復(fù)雜度,空間復(fù)雜度,常數(shù)等
  • 實(shí)現(xiàn)復(fù)雜度:算法實(shí)現(xiàn)起來(lái)很難,不易于測(cè)試和維護(hù)的話,也是很大的問(wèn)題
  • 適用性:在特定的業(yè)務(wù)場(chǎng)景下,是否有更合適的算法?

總的來(lái)說(shuō),要具體情況具體分析,在滿足業(yè)務(wù)的同時(shí)要簡(jiǎn)潔的解決問(wèn)題。

go 生成區(qū)間隨機(jī)數(shù)

// 函 數(shù):生成隨機(jī)數(shù) 
// 概 要: 
// 參 數(shù): 
//  min: 最小值 
//  max: 最大值 
// 返回值: 
//  int64: 生成的隨機(jī)數(shù) 
func RandInt64(min, max int64) int64 { 
 if min >= max || min == 0 || max == 0 { 
  return max 
 } 
 return rand.Int63n(max-min) + min 
} 

參考文章: 【BAT后臺(tái)入門】第二課:數(shù)組與排序

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • Go語(yǔ)言中的逃逸分析究竟是什么?

    Go語(yǔ)言中的逃逸分析究竟是什么?

    這篇文章主要介紹了Go語(yǔ)言中的逃逸,套喲究竟是什么呢?通俗來(lái)講,當(dāng)一個(gè)對(duì)象的指針被多個(gè)方法或線程引用時(shí),我們稱這個(gè)指針發(fā)生了“逃逸”。下面文章將詳細(xì)介紹Go語(yǔ)言中的逃逸,需要的朋友可以參考一下
    2021-09-09
  • Golang 定時(shí)器的終止與重置實(shí)現(xiàn)

    Golang 定時(shí)器的終止與重置實(shí)現(xiàn)

    在實(shí)際開(kāi)發(fā)過(guò)程中,我們有時(shí)候需要編寫(xiě)一些定時(shí)任務(wù)。很多人都熟悉定時(shí)器的使用,那么定時(shí)器應(yīng)該如何終止與重置,下面我們就一起來(lái)了解一下
    2021-08-08
  • Golang 實(shí)現(xiàn)復(fù)制文件夾同時(shí)復(fù)制文件

    Golang 實(shí)現(xiàn)復(fù)制文件夾同時(shí)復(fù)制文件

    這篇文章主要介紹了Golang 實(shí)現(xiàn)復(fù)制文件夾同時(shí)復(fù)制文件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-12-12
  • 詳解golang開(kāi)發(fā)中http請(qǐng)求redirect的問(wèn)題

    詳解golang開(kāi)發(fā)中http請(qǐng)求redirect的問(wèn)題

    這篇文章主要介紹了詳解golang開(kāi)發(fā)中http請(qǐng)求redirect的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • Go語(yǔ)言學(xué)習(xí)之接口使用的示例詳解

    Go語(yǔ)言學(xué)習(xí)之接口使用的示例詳解

    Go語(yǔ)言并沒(méi)有類的定義,接口可以說(shuō)Go語(yǔ)言最接近于類的實(shí)現(xiàn)方式,但是更輕量。本文將通過(guò)一些簡(jiǎn)單的示例和大家介紹下Go語(yǔ)言中接口的使用,感興趣的可以學(xué)習(xí)一下
    2022-11-11
  • golang中如何使用kafka方法實(shí)例探究

    golang中如何使用kafka方法實(shí)例探究

    Kafka是一種備受歡迎的流處理平臺(tái),具備分布式、可擴(kuò)展、高性能和可靠的特點(diǎn),在處理Kafka數(shù)據(jù)時(shí),有多種最佳實(shí)踐可用來(lái)確保高效和可靠的處理,這篇文章將介紹golang中如何使用kafka方法
    2024-01-01
  • go語(yǔ)言題解LeetCode1128等價(jià)多米諾骨牌對(duì)的數(shù)量

    go語(yǔ)言題解LeetCode1128等價(jià)多米諾骨牌對(duì)的數(shù)量

    這篇文章主要為大家介紹了go語(yǔ)言題解LeetCode1128等價(jià)多米諾骨牌對(duì)的數(shù)量示例詳解,
    2022-12-12
  • Go Gin框架中的binding驗(yàn)證器使用小結(jié)

    Go Gin框架中的binding驗(yàn)證器使用小結(jié)

    Gin框架中的binding驗(yàn)證器為我們提供了簡(jiǎn)便的數(shù)據(jù)綁定和驗(yàn)證功能,通過(guò)合理使用binding和validate標(biāo)簽,我們可以確保API接口的數(shù)據(jù)合法性和完整性,這篇文章主要介紹了Go Gin框架中的binding驗(yàn)證器使用指南,需要的朋友可以參考下
    2024-07-07
  • C語(yǔ)言的10大基礎(chǔ)算法

    C語(yǔ)言的10大基礎(chǔ)算法

    算法是一個(gè)程序和軟件的靈魂,作為一名優(yōu)秀的程序員,只有對(duì)一些基礎(chǔ)的算法有著全面的掌握,才會(huì)在設(shè)計(jì)程序和編寫(xiě)代碼的過(guò)程中顯得得心應(yīng)手。這篇文章主要介紹了C語(yǔ)言的10大基礎(chǔ)算法,需要的朋友可以參考下
    2019-09-09
  • go語(yǔ)言使用Casbin實(shí)現(xiàn)角色的權(quán)限控制

    go語(yǔ)言使用Casbin實(shí)現(xiàn)角色的權(quán)限控制

    Casbin是用于Golang項(xiàng)目的功能強(qiáng)大且高效的開(kāi)源訪問(wèn)控制庫(kù)。本文主要介紹了go語(yǔ)言使用Casbin實(shí)現(xiàn)角色的權(quán)限控制,感興趣的可以了解下
    2021-06-06

最新評(píng)論