排序算法之——选择排序
1.算法思想
选择排序,从头至尾扫描序列,找出无序区最小的一个元素,和有序区的最后一个元素比较,如果较小就交换元素,如果相等就不交换元素,接着下一次循环(有序区不断增加,无序区不断往后减少),执行同样的操作,最终得到一个有序序列。
2.C++实现
#include <iostream> using namespace std; //交换2个数 void swap(int *p,int *q) { int temp; temp=*p; *p=*q; *q=temp; } //p表示数组首地址,n表示数组大小 void select_sort(int *p,int n) { //i表示有序区的末尾位置 //j表示无序区的首位置 //min表示最小值的位置 int i,j,min; for(i=0;i<n;i++) { //假设数组的无序区第一个数是最小的 min=i; //先找到从i+1~4之间最小的数 for(j=i+1;j<5;j++) { if(*(p+j)<*(p+min)) { min=j; } } /*如果最小的值的下标min与当前 循环变量i(即有序区的末尾位置)的值不相等,则交换他们的值 */ if(min!=i) { swap(*(p+i),*(p+min)); } } } int main() { int a[5]={23,7,1,9,0}; //排序前 for(int k=0;k<5;k++) { cout<<a[k]<<" "; } cout<<endl; //得到数组的长度 int arrlength = (sizeof(a)) / (sizeof(a[0])); //排序 select_sort(a,arrlength); //排序后 for(int k=0;k<5;k++) { cout<<a[k]<<" "; } return 0; }
运行结果:
参考文章:
https://www.cnblogs.com/skywang12345/p/3597641.html#a42
https://www.runoob.com/w3cnote/selection-sort.html
转载文章链接已标明,如有侵权请告知。文章仅作为知识记忆所用,如有错误,敬请指正。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?