简单选择排序(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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • SVN 配置ip访问[通俗易懂]

    SVN 配置ip访问[通俗易懂]之前为了对visualsvnserver服务器进行IP访问控制配置,参考了http://blog.sina.com.cn/s/blog_6dc4dbed0100zass.html介绍的办法解决了这个问题最近svnserver准备升级到V3.7.1版本,发现之前的办法不好使了,启动就直接报错:invalidcommand’Order’,度娘了一把,原来是Apache版本变化导致的.最新…

    2025年11月5日
    2
  • 头文件string与string.h的区别_conio h是什么头文件

    头文件string与string.h的区别_conio h是什么头文件一般一个C++的老的带“.h”扩展名的库文件,比如iostream.h,在新标准后的标准库中都有一个不带“.h”扩展名的相对应,区别除了后者的好多改进之外,还有一点就是后者的东东都塞进了“std”名字空间中。  但唯独string特别。 问题在于C++要兼容C的标准库,而C的标准库里碰巧也已经有一个名字叫做“string.h”的头文件,包含一些常用的C字符串处理函数,比

    2025年11月2日
    3
  • ubuntu命令chmod755

    ubuntu命令chmod755使用方式:在终端切换到文件目录输入chmod775hello.py这样就将hello.py变成了可执行文件当然作为python文件还需要再开头加上#!/usr/bin/envpython用于适应linux环境。chmod是Linux下设置文件权限的命令,后面的数字表示不同用户或用户组的权限。一般是三个数字:第一个数字表示文件所有者的权限第二个数字表示与文…

    2022年7月16日
    37
  • 谷歌的技术_探究GNSS技术在

    谷歌的技术_探究GNSS技术在文章目录引言TrueTime事务读写事务快照读只读事务总结引言Spanner是一个全球分布式的数据库,从数据模型来看Spanner很像BigTable,都是类似于key对应着一行数据,但是却并不一样,Spanner中衍生出了“目录”的概念(把两张表合并存储)。这并不是重点,Spanner的重是它是第一个在全球范围内传递数据且保证外部一致的分布式事务的系统,且支持几种特定的事务,这显然是一个很困难的问题,我们会在文章中加以描述,这篇文章主要对Spanner的事务以及实现事务所使用的TrueTimeAP

    2025年6月2日
    3
  • pool2_commons pool

    pool2_commons pool一次服务上线没多久,页面处于刷新状态,系统发生假死,查看后台日志,并未发现任何的异常信息,在请求接口处增加debug日志后发现,程序在执行到数据库查询相关的地方卡死了。怀疑是数据库连接的问题,但是使用Navicat连接数据库正常。通过jstack导出线程快照发现,jstack<pid>>>jstack.log大量处于WAITTING状态的线程,而这些线程都是在调用borrowObject方法,这个是apachecommon…

    2022年9月19日
    3
  • 【PLSQL】package包的使用

    【PLSQL】package包的使用

    2021年12月16日
    48

发表回复

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

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