婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Golang 實現(xiàn)插入排序的方法示例(2種)

Golang 實現(xiàn)插入排序的方法示例(2種)

熱門標簽:賺地圖標注的錢犯法嗎 智能電銷機器人營銷 澳門防封電銷卡 福州鐵通自動外呼系統(tǒng) 長沙ai機器人電銷 烏魯木齊人工電銷機器人系統(tǒng) 濮陽自動外呼系統(tǒng)代理 廣東語音外呼系統(tǒng)供應商 地圖標注測試

再次研究了插入排序的概念:定義一個有序的數(shù)據(jù)序列a,將待排序的序列b中的數(shù)依次插入到a的合適位置,插入后仍然有序

總結其與冒泡、選擇的區(qū)別在于,內(nèi)部迭代的次數(shù)是逐漸增大的,二后兩者隨著排序進行迭代次數(shù)逐漸減少

嘗試基于Go的實現(xiàn):

插入排序都采用in-place在數(shù)組上實現(xiàn)。具體算法描述如下:

  • 從第一個元素開始,該元素可以認為已經(jīng)被排序 取出下一個元素
  • 在已經(jīng)排序的元素序列中從后向前掃描
  • 如果該元素(已排序)大于新元素,將該元素移到下一位置
  • 重復步驟3,直到找到已排序的元素小于或者等于新元素的位置 將新元素插入到該位置后
  • 將新元素插入到該位置后
  • 重復步驟2~5

兩種實現(xiàn)方式:1,新建切片; 2,在原切片中進行元素交換

方式一:新建切片

package main

import "fmt"

func main() {
 arr := []int{1, 0, 5, 7, 8, 5, 3, 6, 9, 2, 54, 33, 66}
 newArr := []int{}
 insertionSort(arr, newArr)
 fmt.Println(newArr)
}

/**
插入排序法:取原數(shù)組old中第一個值作為新數(shù)組中的第一個值,然后遍歷old,將每個元素按照條件插入到新數(shù)組中
時間復雜度:O(n^2)
*/
func insertionSort(old []int, new *[]int) {
 if len(*new) == len(old) {
 return
 }
 current := len(*new)
 *new = append(*new, old[current])
 sort(*new)
 insertionSort(old, new)
}

func sort(arr []int) {
 for i := len(arr) - 1; i > 0; i-- {
 if arr[i]  arr[i-1] {
  arr[i], arr[i-1] = arr[i-1], arr[i]
 }
 }
}


注意:insertionSort()函數(shù)中的第二個參數(shù)為切片的指針,不然打印出來的的新數(shù)組為空

原因:雖然切片是指針傳遞,這是指切片內(nèi)的各個元素是指針傳遞,對于切片本身仍是值傳遞

證明:

package test

import (
 "fmt"
 "testing"
)

func TestSlice(t *testing.T) {
 slice1 := []string{"zhang", "san"}
 fmt.Printf("%p\n", slice1)
 fmt.Printf("%p\n", slice1[1])
 modify(slice1)
 fmt.Println(slice1)
}
func modify(data []string) {
 fmt.Printf("%p\n", data)
 fmt.Printf("%p\n", data[1])
 data[1] = "si"
}

打印結果:

0xc0420e4680
0xc0420e46b0
0xc0420e46c0
0xc0420e46b0
[zhang si]

引申:Go 語言里的引用類型有如下幾個:切片、映射、通道、接口和函數(shù)類型。當聲明上述類型的變量時,創(chuàng)建的變量被稱作標頭(header)值。從技術細節(jié)上說,字符串也是一種引用類型。每個引用類型創(chuàng)建的標頭值是包含一個指向底層數(shù)據(jù)結構的指針。因為標頭值是為復制而設計的,所以永遠不需要共享一個引用類型的值。標頭值里包含一個指針,因此通過復制來傳遞一個引用類型的值的副本,本質(zhì)上就是在共享底層數(shù)據(jù)結構

結論:不會對切片進行增加或刪除操作時(也就是長度不會改變),切片作為參數(shù)在函數(shù)間的傳遞不需使用指針。但是如果切片需要進行增加或刪除元素的操作,并且原函數(shù)需要調(diào)用更新后的切片,那么在原函數(shù)調(diào)用其它函數(shù)時,就需要用切片的指針作為參數(shù)。

方式二:在原切片中進行元素交換

func method2(arr []int) {
 if len(arr)  2 {
 return
 }
 for i := 1; i  len(arr); i++ {
 for j := i; j > 0; j-- {
  if arr[j]  arr[j-1] {
  arr[j], arr[j-1] = arr[j-1], arr[j]
  }
 }
 }
}
 

由于不用創(chuàng)建新的切片,不用進行插入操作,只需要交換操作,所以要較方法一速度快些

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Go語言排序算法之插入排序與生成隨機數(shù)詳解
  • Go語言實現(xiàn)冒泡排序、選擇排序、快速排序及插入排序的方法

標簽:德州 貴陽 廣西 西雙版納 阿克蘇 太原 慶陽 調(diào)研邀請

巨人網(wǎng)絡通訊聲明:本文標題《Golang 實現(xiàn)插入排序的方法示例(2種)》,本文關鍵詞  Golang,實現(xiàn),插入,排序,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Golang 實現(xiàn)插入排序的方法示例(2種)》相關的同類信息!
  • 本頁收集關于Golang 實現(xiàn)插入排序的方法示例(2種)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 蛟河市| 甘洛县| 肥乡县| 马鞍山市| 建宁县| 天津市| 云林县| 循化| 兖州市| 栾城县| 平顶山市| 肃宁县| 龙州县| 六盘水市| 行唐县| 且末县| 贵溪市| 郯城县| 瓦房店市| 平江县| 六枝特区| 文化| 斗六市| 通道| 宜昌市| 兴文县| 兴义市| 和顺县| 昆明市| 泾源县| 阿拉善左旗| 巴林右旗| 长宁县| 栾城县| 浙江省| 石门县| 句容市| 泸定县| 龙南县| 林西县| 贵州省|