选择排序(C语言实现)
2023-06-13 09:12:25 时间
大家好,又见面了,我是你们的朋友全栈君。
选择排序(C语言实现)
实现原理:
给出一组数据,第1轮在待排序记录r[1]-r[n]中选出最小的记录,将它与r[1]交换;第2轮在待排序记录r[2]-r[n]中选出最小的记录,将它与r[2]交换;以此类推,第i趟在待排序记录r[i]~r[n]中选出最小的记录,将它与r[i]交换,使有序序列不断增长直到全部排序完毕。
代码
初始序列:{49 27 65 97 76 12 38}
第1趟:12与49交换:12{27 65 97 76 49 38}
第2趟:27不动 :12 27{65 97 76 49 38}
第3趟:65与38交换:12 27 38{97 76 49 65}
第4趟:97与49交换:12 27 38 49{76 97 65}
第5趟:76与65交换:12 27 38 49 65{97 76}
第6趟:97与76交换:12 27 38 49 65 76 97 完成
括号内为无序区域,括号外为有序区;
for(i=0;i<10;i++)
{
min=i;
for(j=i+1;j<10;j++)
{
if(a[min]>a[j])//如果有一个值比开始的值小
min=j;//将最小的值j的序号给min
}
temp=a[min];//交换最最小值
a[min]=a[i];
a[i]=temp;
}
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/153019.html原文链接:https://javaforall.cn
相关文章
- C语言中void代表什么意思?
- C语言和JAVA的区别[通俗易懂]
- 用C语言实现快速排序算法「建议收藏」
- 蓝桥杯 分苹果(线段树)---------C语言—菜鸟级
- 【安全算法之SHA384】SHA384摘要运算的C语言源码实现
- 【C语言进阶】使用memcpy你需要注意的一个问题
- [linux] C语言Linux系统编程进程基本概念详解编程语言
- Linux C语言实现文件快速排序(linuxc文件排序)
- Linux下C语言源文件编程(linuxc源文件)
- 快速排序算法,C语言快速排序算法详解
- 指针与数组的关系,C语言指针和数组的关系详解
- fread和fwrite函数,C语言fread和fwrite函数详解
- C语言三个数从小到大排序/输出
- C语言希尔排序算法
- 快速排序Linux C语言实现(linuxc排序)
- 教程C语言操作Oracle数据库的实例教程(coracle实例)
- MySQL负载均衡实现C语言最优性能(c mysql负载均衡)
- 如何使用C语言在MySQL中存储图片(c mysql怎么存图片)
- MySQL示例教程快速上手C语言(c mysql demo)
- C语言与Oracle结合,实现时间戳功能(c oracle 时间戳)
- C语言使用stdlib.h库函数的二分查找和快速排序的实现代码
- C语言实现排序算法之归并排序详解
- C语言kmp算法简单示例和实现原理探究