欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 培训 > 【基础2】选择排序

【基础2】选择排序

2025/12/14 10:08:28 来源:https://blog.csdn.net/Brilliant2021/article/details/146020789  浏览:    关键词:【基础2】选择排序
核心思路

选择排序是冒泡排序的改进方法,冒泡排序一大缺点是多次调序,选择排序每次只寻找当前最小元素,并将其放到已排序序列的末尾,即每一轮只进行一次调序

特点:

  • 每轮确定一个元素的最终位置
  • ​不稳定排序:可能改变相等元素的相对位置
  • ​原地排序:不需要额外存储空间
复杂度
情况时间复杂度空间复杂度
所有情况O(n²)O(1)
优缺点

优点

  1. 交换次数少(每轮最多交换1次)
  2. 实现简单直观
  3. 内存写入次数少(适合Flash存储器)

缺点

  1. 时间复杂度始终是O(n²)
  2. 不稳定排序
  3. 对部分有序数组没有效率提升

适用场景

  • 小规模数据排序
  • 对内存写入次数敏感的场景
代码实现(Java)
public class SelectionSort {public static void main(String[] args) {int[] arr = {5, 3, 8, 4, 2};selectionSort(arr);System.out.println(Arrays.toString(arr)); }/*** 选择排序*/public static void selectionSort(int[] arr) {if (arr == null || arr.length < 2) return;int n = arr.length; for (int i = 0; i < n - 1; i++) {int minIndex = i;for (int j = i + 1; j < n; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}// 将最小值交换到当前位置if (minIndex != i) {int temp = arr[i];arr[i] = arr[minIndex];arr[minIndex] = temp;}}}
}
过程示例

初始:  5 3 8 4 2  

第1轮:2 | 3 8 4 5  

第2轮:2 3 | 8 4 5  

第3轮:2 3 4 | 8 5  

第4轮:2 3 4 5 | 8  

结束:   2 3 4 5 8

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词