91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

golang中有哪些基礎排序方法

發布時間:2021-07-06 15:06:28 來源:億速云 閱讀:138 作者:Leah 欄目:大數據

這篇文章給大家介紹golang中有哪些基礎排序方法,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

package main
import (
  "fmt"
)

func main() {
  var (
     data = []int{63, 10, 50, 20, 12, 19, 13, 17, 88}
  )

  fmt.Println(sortMaoBao(data))
  fmt.Println(sortChoice(data))
  fmt.Println(sortInsert(data))
}

// sortChoice 選擇排序
func sortChoice(data []int) []int {
  var (
     l = len(data) - 1
  )
  for l > 0 {
     var max = 0
     // 選擇最大的數據進行排列
     for i := 1; i < l+1; i++ {
        if data[i] > data[max] {
           max = i
        }
     }
     data[l], data[max] = data[max], data[l]
     l--
  }
  return data
}

// sortMaoBao 冒泡排序
func sortMaoBao(data []int) []int {

  var (
     l = len(data) - 1
  )

  for l > 0 {
     for j := 0; j < l; j++ {
        // 兩個數據比較,大的進行交換數據
        if data[j] >= data[j+1] {
           data[j], data[j+1] = data[j+1], data[j]
        }
     }
     l--
  }
  return data
}

// sortInsert 插入排序
func sortInsert(data []int) []int {
  var (
     l = len(data) - 1
  )
  for l > 0 {
     currentValue := data[l]
     position := l
     for position > 0 && data[position-1] > currentValue {
        data[position] = data[position-1]
        position = position - 1
        data[position] = currentValue
     }

     l--
  }
  return data
}

關于golang中有哪些基礎排序方法就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴东县| 历史| 花莲县| 舞阳县| 五华县| 安康市| 教育| 什邡市| 昭觉县| 肇源县| 色达县| 寿宁县| 松原市| 嘉黎县| 桐城市| 青铜峡市| 华容县| 葵青区| 青岛市| 尼玛县| 三河市| 五莲县| 昌邑市| 务川| 镇巴县| 广西| 杭锦旗| 绥棱县| 龙岩市| 亳州市| 锡林郭勒盟| 鸡西市| 甘德县| 元阳县| 石门县| 会昌县| 时尚| 马关县| 湘乡市| 慈溪市| 和田市|