亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

使用Golang怎么實現一個插入排序算法

發布時間:2021-04-06 16:25:54 來源:億速云 閱讀:107 作者:Leah 欄目:編程語言

使用Golang怎么實現一個插入排序算法?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

插入排序都采用in-place在數組上實現。具體算法描述如下:

  • 從第一個元素開始,該元素可以認為已經被排序 取出下一個元素

  • 在已經排序的元素序列中從后向前掃描

  • 如果該元素(已排序)大于新元素,將該元素移到下一位置

  • 重復步驟3,直到找到已排序的元素小于或者等于新元素的位置 將新元素插入到該位置后

  • 將新元素插入到該位置后

  • 重復步驟2~5

使用Golang怎么實現一個插入排序算法

兩種實現方式: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)
}

/**
插入排序法:取原數組old中第一個值作為新數組中的第一個值,然后遍歷old,將每個元素按照條件插入到新數組中
時間復雜度: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()函數中的第二個參數為切片的指針,不然打印出來的的新數組為空

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

證明:

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

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

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

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]
  }
 }
 }
}

看完上述內容,你們掌握使用Golang怎么實現一個插入排序算法的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

仪征市| 大足县| 红安县| 年辖:市辖区| 九龙坡区| 北流市| 昭平县| 松江区| 新乐市| 建水县| 海伦市| 平南县| 衡阳市| 滦平县| 万山特区| 张掖市| 马龙县| 桂东县| 内丘县| 思茅市| 息烽县| 孟州市| 康平县| 玉树县| 三台县| 门源| 乃东县| 林西县| 拜城县| 南澳县| 将乐县| 合肥市| 来宾市| 西平县| 辽源市| 定南县| 石林| 华池县| 安庆市| 西青区| 北安市|