选择排序
算法说明与代码实现:
以下是使用Go语言实现的选择排序算法示例代码:
package main
import "fmt"
func selectionSort(arr []int) {
n := len(arr)
for i := 0; i < n-1; i++ {
minIndex := i
for j := i + 1; j < n; j++ {
if arr[j] < arr[minIndex] {
minIndex = j
}
}
arr[i], arr[minIndex] = arr[minIndex], arr[i]
}
}
func main() {
// 待排序的数组
arr := []int{64, 34, 25, 12, 22, 11, 90}
fmt.Println("排序前:", arr)
// 调用选择排序函数
selectionSort(arr)
fmt.Println("排序后:", arr)
}
在上述示例中,我们定义了一个selectionSort
函数来实现选择排序算法。该函数接受一个整数切片作为输入,并对切片进行升序排序。选择排序的基本思想是每次从未排序部分选择最小的元素,将其与未排序部分的第一个元素交换位置。
在main
函数中,我们定义了一个待排序的整数切片arr
,并打印出排序前的切片内容。然后,我们调用selectionSort
函数对切片进行排序。最后,我们再次打印排序后的切片内容。
运行上述代码将输出以下结果:
排序前: [64 34 25 12 22 11 90]
排序后: [11 12 22 25 34 64 90]
可以看到,选择排序算法成功将切片按照升序进行了排序。选择排序的时间复杂度为O(n^2),无论输入数据的初始顺序如何,选择排序总是需要进行相同次数的比较和交换操作。