白话选择排序

核心原理

找最小游戏。开始假设第1个最小,从剩余数字找出最小,然后和第1个数交换位置;从剩余数字中找出最小再和第2个数交换位置;重复这个过程,直到所有数都排好序。

通俗步骤

  1. 假设第1个数最小;
  2. 从剩余数字中找出最小,和第1个数交换位置;
  3. 从除了第1个的数字中找出最小,和第2个数交换位置;
  4. 从除了第1、2个的数字中找出最小,和第3个数交换位置;
  5. 重复过程;

举例演示 3,1,4,2

第一轮

假设3最小;1,4,2依次比较,找出最小1,1和3交换 -> 1,3,4,2

第二轮

3,4,2依次比较,找出最小2,2和3交换 -> 1,2,4,3

第三轮

4,3依次比较,找出最小3,4和3交换 -> 1,2,3,4

代码示例

go 复制代码
package main

import "fmt"

// 选择排序 - 升序
func selectionSort(arr []int) {
	n := len(arr)

	// 外层循环:控制轮次,共 n-1 轮
	for i := 0; i < n-1; i++ {
		// 假设当前位置是最小值的索引
		minIndex := i

		// 内层循环:在 i 后面找最小值
		for j := i + 1; j < n; j++ {
			if arr[j] < arr[minIndex] {
				minIndex = j // 更新最小值索引
			}
		}

		// 找到最小值后,和当前 i 位置交换
		if minIndex != i {
			arr[i], arr[minIndex] = arr[minIndex], arr[i]
		}
	}
}

func main() {
	arr := []int{3,1,4,2}
	fmt.Println("排序前:", arr)	// [3,1,4,2]

	selectionSort(arr)
	fmt.Println("排序后:", arr)	// [1,2,3,4]
}
相关推荐
计算机安禾6 小时前
【算法分析与设计】第19篇:二分图匹配与指派问题
大数据·人工智能·算法
学习中.........6 小时前
从傅里叶级数到傅里叶变换:详细的数学推导
算法
宇宙realman_9996 小时前
420B污染度等级查询代码
java·开发语言·算法
Dfreedom.6 小时前
深度学习量化技术全景解析:从校准算法到量化算子的完整指南
人工智能·深度学习·算法·量化·模型加速
如竟没有火炬6 小时前
乘法表中第K小的数——二分
开发语言·数据结构·python·算法·leetcode·职场和发展·动态规划
2401_876964136 小时前
27考研李艳芳网课|王谱2027数学讲义
人工智能·经验分享·深度学习·考研·算法·计算机视觉·概率论
努力的小张.7 小时前
最大子段和(前缀和解决)
算法
khalil10207 小时前
代码随想录算法训练营Day-58 图论08 | 拓扑排序精讲、dijkstra(朴素版)精讲
c++·算法·图论·dijkstra·拓扑排序·prim·最短距离
吃好睡好便好7 小时前
矩阵的乘法运算
数据结构·人工智能·学习·线性代数·算法·matlab·矩阵