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


相关推荐

  • 谷歌浏览器驱动镜像

    谷歌浏览器驱动镜像一、背景在使用selenium时,经常会提示谷歌版本包和当前的selenium不匹配例如下报错:selenium.common.exceptions.SessionNotCreatedException:Message:sessionnotcreated:ThisversionofChromeDriveronlysupportsChromeversion90二、谷歌浏览器驱动镜像下载ChromeDriverMirror…

    2022年6月12日
    155
  • JAVA(计算机编程语言)

    JAVA(计算机编程语言)走进JAVA//公共的类类名:要求与文件保持一致,每一个单词首字母大写publicclassHelloWorld{//类的开始 //公共的静态的没有返回值类型的主方法()->参数列表 publicstaticvoidmain(String[]args){//方法的开始 //系统输出打印()->内容””中的内容原封不动显示->字符串 System.out.println(“HelloWorld!!!”);//;结束语句

    2022年7月8日
    25
  • 簡單SQL存儲過程實例

    簡單SQL存儲過程實例

    2021年12月3日
    35
  • HTTP默认端口_http协议使用的端口号

    HTTP默认端口_http协议使用的端口号HTTP默认端口80是http协议的默认端口,是在输入网站的时候其实浏览器(非IE)已经帮你输入协议了,所以你输入http://baidu.com,其实是访问http://baidu.com:80。而8080,一般用与webcahe,完全不一样的两个,比如linux服务器里apache默认跑80端口,而apache-tomcat默认跑8080端口,其实端口没有实际意义只是一个接口,主要是看服务的监听端口。443是https的默认端口端口号标识了一个主机上进行通信的不同的应用程序。 H.

    2022年9月16日
    0
  • MySQL 拼接字符串_合并字符串的库函数是

    MySQL 拼接字符串_合并字符串的库函数是原文请查看MySQL拼接字符串函数CONCAT这里selectconcat(updatesale_personbodysetoldill_code=/,code,/,oldill_reportname=/,reportname,/,oldill_oldtitle=/,oldtitle,/whereoldill=)fromtj_oldill

    2022年9月1日
    2
  • 2020年3月23日阿里笔试题[通俗易懂]

    2020年3月23日阿里笔试题[通俗易懂]2020年3月23日阿里笔试题题目描述题目分析  这是阿里的第二场笔试,本来觉得没啥好写的,一道排列组合,一道迷宫。没有什么发挥的空间。但是后来在和大家讨论的过程中,把这道题的公司给敲出来了,但是这公式也不能白敲,干脆写一篇文章总结一下。题目描述一共n个人,从中选出任意个人组成一队,我们不妨记为k,再从k个人选出一人做队长。题目分析  这是一个典型的排列组合问题,从n个人选出k个,可…

    2022年5月22日
    26

发表回复

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

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