news 2026/7/4 18:14:52

选择排序--自学笔记

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
选择排序--自学笔记

选择排序

学习目标:

1.选择排序的基本思想

2.二元选择排序

3.冒泡排序和选择排序的异同

4.复杂度分析

1.选择排序的基本思想

1.1基本思想

双重循环遍历数组,每经过一轮比较,找到最小或最大元素的下标,将其换至首位!

经过六轮选择,完成排序

1.2代码实现

publicstaticvoidselectSort(int[]arr){intminIndex;intlen=arr.length;for(inti=0;i<len-1;i++){minIndex=i;for(intj=i+1;j<len;j++){if(arr[j]<arr[minIndex]){minIndex=j;}}swap(arr,i,minIndex);}}

2.二元选择排序

2.1 二元选择排序的思想

既然一次选择中要找出最小值,何不把最大值也找出来

2.2 代码实现

publicstaticvoidselectSort(int[]arr){intminIndex,maxIndex;intlen=arr.length;for(inti=0;i<len-1;i++){minIndex=i;maxIndex=i;//每轮最末尾 i 位 已有序for(intj=i+1;j<len-i;j++){if(arr[j]<arr[minIndex]){minIndex=j;}if(arr[j]>arr[maxIndex]){maxIndex=j;}}//min == max 说明所有元素相等 提前退出if(minIndex==maxIndex)break;swap(arr,i,minIndex);//当前数组的末尾下标 len - 1 - i//特殊情况:此时maxIndex == i//而 i 刚刚与 minIndex 互换//更新为 maxIndex = minIndexif(maxIndex==i)maxIndex=minIndex;swap(arr,len-1-i,maxIndex);}}

3.冒泡排序和选择排序的异同

3.1 相同点

1.都是两层循环,时间复杂度为O(n2)

2.都只使用有限个变量,空间复杂度为O(1)

3.2 不同点

1.冒泡排序在比较过程中不断交换

2.选择排序增加一个变量保存最小值/最大值的下标,遍历完成后才交换,

减少了交换的次数

*3.冒泡排序是稳定的,而选择排序是不稳定的

3.3 排序算法的稳定性

假定在待排序的记录序列中,存在多个具有相同的关键字的记录,

若经过排序,这些记录的相对次序保持不变,即

在原序列中,r[i] = r[j] ,且r[i] 在 r[j] 之前,而在排序后的序列中,

r[i] 仍在 r[j] 之前,相对顺序依然不变,

则称这种排序算法是稳定的;

否则称为不稳定的

3.4 什么情况下要用的排序算法的稳定性?

将要排序的内容是一个对象的多个属性,

且其原本的顺序存在意义,

如果要在二次排序后保持原有排序的意义,

则需要用到稳定性

4.复杂度分析

1.时间复杂度:O(n2)

2.空间复杂度:O(1)

215. 数组中的第K个最大元素 - 力扣(LeetCode)

2.空间复杂度:O(1)

215. 数组中的第K个最大元素 - 力扣(LeetCode)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/5 15:01:54

【RealEarthStudio】安装并配置Redis数据库

安装并配置Redis数据库 引言一、主要功能二、实现步骤2.1 Windows版本Redis下载2.2 开始安装Redis2.3 检验安装效果 引言 计算机专业硕士在读&#xff0c;主要研究方向是特定目标大斜视角目标检测与定位。因为要做的是特定目标&#xff0c;公开数据集较少&#xff0c;经过多方…

作者头像 李华
网站建设 2026/7/4 11:31:41

VSCode + Qiskit智能提示配置全攻略(从零到自动补全的终极指南)

第一章&#xff1a;VSCode Qiskit 的代码补全 在量子计算开发中&#xff0c;高效的编码体验离不开强大的代码补全功能。Visual Studio Code&#xff08;VSCode&#xff09;结合 Qiskit 开发插件&#xff0c;为开发者提供了智能提示、语法高亮和自动补全能力&#xff0c;显著提升…

作者头像 李华
网站建设 2026/7/3 10:24:33

GEO关键词AI排名优化哪家企业好

GEO关键词AI排名优化&#xff1a;至灵企业服务——您的理想之选在当今数字化营销竞争日益激烈的时代&#xff0c;企业要想在搜索引擎中脱颖而出&#xff0c;吸引更多潜在客户&#xff0c;关键词排名优化就显得尤为关键。特别是对于那些希望精准定位特定地理区域&#xff08;GEO…

作者头像 李华
网站建设 2026/7/4 19:51:20

SeedVR2革命性突破:6GB显存实现专业级视频修复完整指南

在AI视频修复技术快速发展的当下&#xff0c;传统工具对高端硬件的严苛要求已成为技术普及的最大障碍。SeedVR2通过创新的模型优化方案&#xff0c;将显存需求从12GB以上降低至仅需6GB&#xff0c;让RTX 4060等主流显卡也能流畅运行专业级视频修复功能。这项突破性技术为短视频…

作者头像 李华
网站建设 2026/7/3 2:21:01

28、Linux使用技巧与优质信息源汇总

Linux使用技巧与优质信息源汇总 一、多屏幕分辨率设置 在Linux系统中,若你想在图形用户界面(GUI)中切换不同的屏幕分辨率,比如你常用1024 x 768分辨率,但在处理网页时想查看800 x 600甚至640 x 480分辨率下网页在浏览器中的显示效果,可按以下步骤操作: 1. 定位配置文…

作者头像 李华
网站建设 2026/7/3 2:03:08

30、Linux 系统使用与配置全解析

Linux 系统使用与配置全解析 1. 符号与数字相关 在 Linux 系统中,各种符号和数字有着特定的含义和用途。例如: | 符号 | 含义及用途 | | — | — | | *(星号) | 用于通配符扩展,在文件查找等操作中使用,如在命令中可表示匹配任意数量的任意字符,出现于 172、186 - …

作者头像 李华