您好,登錄后才能下訂單哦!
選擇排序的原理:
每次從余下的數中找最小的,并排到余下的數的最開頭。
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開始,依次向右
// 從i右側的所有元素中找出當前最小值所在的下標
for j := length - 1; j > i; j-- {
if values[j] < values[min] {
min = j
}
}
//fmt.Printf("i:%d min:%d\n", i, min)
// 把每次找出來的最小值與之前的最小值做交換
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)
}
// 找到集合中最小的數的下標
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) // 每次循環都找到當前數組中最小的加入到結果集中
result = append(result, arr[smallestIdx])
arr = append(arr[:smallestIdx], arr[smallestIdx+1:]...) //從切片中移除指定下標的元素
}
return result
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。