白话选择排序

核心原理

找最小游戏。开始假设第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]
}
相关推荐
Jack206 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树7 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕2 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法