真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

使用Golang怎么實(shí)現(xiàn)一個(gè)插入排序算法

使用Golang怎么實(shí)現(xiàn)一個(gè)插入排序算法?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

專注于為中小企業(yè)提供成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)遵化免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。

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

  • 從第一個(gè)元素開始,該元素可以認(rèn)為已經(jīng)被排序 取出下一個(gè)元素

  • 在已經(jīng)排序的元素序列中從后向前掃描

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

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

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

  • 重復(fù)步驟2~5

使用Golang怎么實(shí)現(xiàn)一個(gè)插入排序算法

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

方式一:新建切片

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

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

證明:

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

打印結(jié)果:

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

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

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

方式二:在原切片中進(jìn)行元素交換

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

看完上述內(nèi)容,你們掌握使用Golang怎么實(shí)現(xiàn)一個(gè)插入排序算法的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


網(wǎng)頁標(biāo)題:使用Golang怎么實(shí)現(xiàn)一個(gè)插入排序算法
文章起源:http://weahome.cn/article/ieopps.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部