【入门级-算法-6、排序算法:选择排序】

1、选择排序算法思想

选择排序是一种简单直观的排序算法。它的基本思想是:

从未排序序列中找到最小(或最大)的元素,将其存放到序列的起始位置(即与起始位置的元素交换)。

然后,再从剩余的未排序元素中继续寻找最小(或最大)的元素。

重复上述过程,直到所有元素均排序完毕。

可以理解为:不断地从后面未排序的部分选择一个最小的,放到前面已排序部分的末尾。

2、算法步骤(以升序为例)

假设有一个数组 arr,长度为 n。

第一轮:从 arr0 到 arrn-1 中找到最小的元素,将其与 arr0 交换。此时 arr0 已排好序。

第二轮:从 arr1 到 arrn-1 中找到最小的元素,将其与 arr1 交换。此时 arr0 和 arr1 已排好序。

...

第 i 轮:从 arri 到 arrn-1 中找到最小的元素,将其与 arri 交换。

如此循环,总共进行 n-1 轮,最后一轮只剩下一个元素,它自然是最大的,无需处理。

3、举例说明

代码实现

#include <stdio.h>

// 选择排序函数 (升序)

void selectionSort(int arr\[\], int n) {

int i, j, minIndex, temp;

// 外层循环,控制轮数,共进行 n-1 轮

for (i = 0; i < n - 1; i++) {

// 1. 假设当前未排序部分的第一个元素是最小的

minIndex = i;

// 2. 内层循环,在未排序部分 (i+1 到 n-1) 中寻找真正的最小值的位置

for (j = i + 1; j < n; j++) {

if (arrj < arrminIndex) {

minIndex = j; // 更新最小元素的索引

}

}

// 3. 如果找到的最小元素不在它应该在的位置 (i),就交换

if (minIndex != i) {

temp = arri;

arri = arrminIndex;

arrminIndex = temp;

}

// 如果 minIndex == i,说明 arri 已经是未排序部分的最小值,无需交换

}

}

// 打印数组的函数

void printArray(int arr\[\], int size) {

int i;

for (i = 0; i < size; i++) {

printf("%d ", arri);

}

printf("\n");

}

// 主函数测试

int main() {

int arr\[\] = {64, 25, 12, 22, 11};

int n = sizeof(arr) / sizeof(arr0); // 计算数组长度

printf("原始数组: \n");

printArray(arr, n);

selectionSort(arr, n); // 调用排序函数

printf("排序后的数组: \n");

printArray(arr, n);

return 0;

}

输出结果

原始数组:

64 25 12 22 11

排序后的数组:

11 12 22 25 64

选择排序是一种教学意义大于实际应用价值的算法。它帮助我们理解排序的基本思想------"选择"和"交换",但在实际项目中,对于性能有要求的场景,通常会使用更高效的算法如快速排序、归并排序等。

相关推荐
BothSavage1 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn1 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽3 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说18 小时前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰21 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法