码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 8-6选择排序-简单选择排序


    原理(从小到大):每轮从待排序的序列中选择最小的元素放到前面

    一.具体实现和效率分析
    第一轮:默认0号位的49最小,从1号位开始遍历列表,找到最小的元素13,与0号位的49交换
    代码:

    int min = 0;
    for (int j = 0 + 1; j < n; j++)
    	{
    		if (a[j] < a[min]) min = j;
    	}
    if(min!=0) swap(a[min], a[0]);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    其中swap为交换函数
    原理

    void swap(int &a, int &b)
    {
    	int t;
    	t = a;
    	a = b;
    	b = t;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    在这里插入图片描述
    第一轮结束,此时有一个元素放到了正确的位置上
    在这里插入图片描述
    第二轮,排1-7,设1最小,从2开始遍历
    找到最小的27,与1号位的38交换
    代码:

    int min = 1;
    		for (int j = 1 + 1; j < n; j++)
    		{
    			if (a[j] < a[min]) min = j;
    		}
    		if(min!=1) swap(a[min], a[1]);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    第二轮结束
    在这里插入图片描述
    第三轮,找到最小的38,与65交换
    在这里插入图片描述
    第四轮,有两个49,选择左边的49,与97交换
    在这里插入图片描述
    第五轮,选择49与76交换
    在这里插入图片描述
    第六轮,选择65,与97交换
    在这里插入图片描述
    第七轮,选择76,与97交换
    在这里插入图片描述
    剩最后一个元素,无需处理。
    因此对n个元素一共需要n-1趟的处理(图中8个元素7趟)

    可以看出,第一轮处理了n-1个元素,第二轮处理了n-2个元素,最后处理了1个元素。因此处理次数=n-1+n-2+…+1=n(n-1)/2,总的元素交换次数不会超过3(n-1)次(含swap中temp的交换)。可以看出,复杂度主要取决于元素的处理次数(比较次数),而该算法中元素是逐个比较的,因此该算法元素的比较次数与初始序列无关,算法的时间复杂度与初始序列无关

    所以总的时间复杂度为O(n²)
    空间复杂度为O(1)

    通过一下三个元素的排序,可以看出该算法是不稳定的
    在这里插入图片描述
    二.代码实现

    #include
    #include
    using namespace std;
    void SelectSort(int a[], int n)
    {
    	for (int i = 0; i < n - 1; i++)
    	{
    		int min = i;
    		for (int j = i + 1; j < n; j++)
    		{
    			if (a[j] < a[min]) min = j;
    		}
    		if(min!=i) swap(a[min], a[i]);
    	}
    }
    int main()
    {
    	int a[5] = { 432,21,46,4322,645 };
    	SelectSort(a, 5);
    	for (int i = 0; i < 5; i++)
    	{
    		cout << a[i] << " ";
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    该算法也适用于链表

    三.总结
    在这里插入图片描述

  • 相关阅读:
    【excel】列转行
    文心一言 VS 讯飞星火 VS chatgpt (168)-- 算法导论13.2 1题
    微信小程序 - - - - - 瀑布流效果实现
    LeetCode(力扣)47.全排列 IIPython
    如何使用PHP替换回车为br
    204318-14-9,依多曲肽,DOTA-TOC
    WPF绑定单变量Binding和绑定多变量MultiBinding 字符串格式化 UI绑定数据,数据变化自动更新UI,UI变化自动更新数据
    GitHub 披露宕机原因;谷歌前 AI 研究员被解雇后成立独立研究所;常用 Linux 桌面版排行榜出炉 | 开源日报
    笔试强训第16天
    开题报告之论文框架
  • 原文地址:https://blog.csdn.net/weixin_45825865/article/details/126089947
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号