您好,登錄后才能下訂單哦!
選擇排序的原理:
每次從余下的數(shù)中找最小的,并排到余下的數(shù)的最開(kāi)頭。
package main
import "fmt"
func main() {
numbers := []int{6, 2, 7, 5, 8, 9}
SelectSort(numbers)
fmt.Println(numbers)
}
func SelectSort(values []int) {
length := len(values)
if length <= 1 {
return
}
for i := 0; i < length; i++ {
min := i // 初始的最小值位置從0開(kāi)始,依次向右
// 從i右側(cè)的所有元素中找出當(dāng)前最小值所在的下標(biāo)
for j := length - 1; j > i; j-- {
if values[j] < values[min] {
min = j
}
}
//fmt.Printf("i:%d min:%d\n", i, min)
// 把每次找出來(lái)的最小值與之前的最小值做交換
values[i], values[min] = values[min], values[i]
//fmt.Println(values)
}
}
更容易理解的版本
package main
import "fmt"
func main() {
arr := []int{9, 5, 4, 6, 7, 2, 1}
rs := SelectSort(arr)
fmt.Println(rs)
}
// 找到集合中最小的數(shù)的下標(biāo)
func findSmallest(arr []int) int {
min := arr[0]
idx := 0
for key, value := range arr {
if value < min {
min = value
idx = key
}
}
return idx
}
// 選擇排序
func SelectSort(arr []int) []int {
var result []int
length := len(arr)
for i := 0; i < length; i++ {
smallestIdx := findSmallest(arr) // 每次循環(huán)都找到當(dāng)前數(shù)組中最小的加入到結(jié)果集中
result = append(result, arr[smallestIdx])
arr = append(arr[:smallestIdx], arr[smallestIdx+1:]...) //從切片中移除指定下標(biāo)的元素
}
return result
}
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。