简单选择排序(C语言)

简单选择排序(C语言)简单选择排序 1 排序原理简单选择排序算法原理 每次从左至右扫描序列 记下最小值的位置 然后将最小值与当前位置的值交换排序过程序列 54321 从小到大排列第一轮 5 4321 当前位置 5 4 3 2 1 中查找比 5 小的最小值 1 交换位置得 1 4 3 2 5 第二轮 1 4 3 2 5 当前位置 4 3 2 5 中查找比 4 小的最小值 2 交换位置得 1 2 3 4 5 第三轮 1 2 3 4 5


数据结构总目录



简单选择排序

1. 图文解析

遍历序列,每次在当前位置向后扫描序列,记下最小值的位置,然后将最小值与当前位置的值交换
在这里插入图片描述

排序过程

序列:{ 
    5, 4, 3, 2, 1 } 从小到大排列 第一轮:{ 
    [5], 4, 3, 2, 1 } 当前位置:[5] 在后序序列{ 
    4,3,2,1 }中查找比[5]小的最小值[1] 交换位置得:{ 
    1, 4, 3, 2, 5 } 第二轮:{ 
    1, [4], 3, 2, 5] 当前位置:[4] 在后序序列{ 
    3, 2, 5 }中查找比[4]小的最小值[2] 交换位置得:{ 
    1, 2, 3, 4, 5 } 第三轮:[1,2,(3),4,5] 当前位置:[3] 在后序序列{ 
    4, 5 }中查找比[3]小的最小值--() 排序结束 

2. 源代码

#include <stdio.h> #define size 10 void SelectSort(int *num, int len) { 
    int i, j, min, temp; for (i = 0; i < len; i++) { 
    // 初始最小值下标 min = i; // 查找后面最小值的下标 for (j = i + 1; j < len; j++) { 
    if (num[min] > num[j]) { 
    min = j; } } // 交换最小值 if (min != i) { 
    temp = num[i]; num[i] = num[min]; num[min] = temp; } } } int main() { 
    int i, num[size] = { 
   65874, 432, 45, 54, 541, 32, 213, 2, 354, 342}; SelectSort(num, size); for (i = 0; i < size; i++) { 
    printf("%d ", num[i]); } printf("\n"); return 0; } 

3. 测试结果

在这里插入图片描述
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233318.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月29日 下午7:01
下一篇 2025年7月29日 下午7:22


相关推荐

  • 剑指offer—12-**–数值的整数次方

    剑指offer—12-**–数值的整数次方

    2021年6月9日
    90
  • 版本号命名规范[通俗易懂]

    版本号命名规范[通俗易懂]写在前面:本文章旨在总结备份、方便以后查询,由于是个人总结,如有不对,欢迎指正;另外,内容大部分来自网络、书籍、和各类手册,如若侵权请告知,马上删帖致歉。原文:http://wsfdl.com/devops/2016/09/27/%E7%89%88%E6%9C%AC%E5%8F%B7.html#首先看看某些常见软件的版本号:LinuxKernel:0.0.1,1.0.0,2.6.32,3.0.18…,若用X.Y.Z表示,则偶数Y表示稳定版本,奇数Y表示开发版本。Windo

    2025年10月25日
    14
  • 方差检验

    方差检验一 一个总体方差的统计推断一个总体方差假设检验的汇总二 两个总体方差的统计推断两个总体方差假设检验的汇总三 多个总体比例的相等性的检验三个或多个相等性的 2 检验多重比较方法四 独立性检验利用样本数据检验两个分类变量的独立性五 拟合优度检验拟合优度检验用来确定一个被抽样的总体是否服从某个特殊的概率分布多项概率分布正态分布

    2026年3月19日
    1
  • webstorm2021 激活码 online【2021免费激活】

    (webstorm2021 激活码 online)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~1…

    2022年3月27日
    80
  • 2022电力电缆复训题库及在线模拟考试

    2022电力电缆复训题库及在线模拟考试题库来源:安全生产模拟考试一点通公众号小程序2022年电力电缆操作证考试题为电力电缆复习题考前押题!2022电力电缆复训题库及在线模拟考试根据电力电缆考试教材。电力电缆考试题库通过安全生产模拟考试一点通准确把握考试要点。1、【单选题】6~35kV三芯交联聚乙烯电缆共用()。(A)A、内护套B、中性导体C、地线2、【单选题】中性点经电阻接地的优点是,()。(A)A、减小了单相接地电流B、不需要增加设备C、加大了电磁干扰3、【单选题】传统的配电网,特别是农村电网多为()。(

    2022年5月7日
    61
  • Centos7监控服务异常发送邮件通知

    Centos7监控服务异常发送邮件通知

    2022年2月19日
    89

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号