【数据结构】第十七弹---C语言实现选择排序

个人主页: 熬夜学编程的小林

💗系列专栏: 【C语言详解】 【数据结构详解】【C++详解】

目录

1、选择排序

1.1、基本思想

1.2、代码实现

1.3、代码测试

1.4、时空复杂度分析

总结


1、选择排序

1.1、基本思想

选择排序是一种简单直观的比较排序算法。该算法的基本思想是在每一轮中选出当前未排序部分的最小(或最大)元素,然后将其放置到未排序序列的起始位置,这个过程一直重复直至整个数组被排序。

选择排序的具体步骤如下:

★ 从数组的当前未排序部分选择最小(或最大)的一个元素
★ 将这个最小(或最大)元素与未排序序列的第一个元素交换位置
★ 然后从剩余未排序的元素中继续这个过程,将每一次找到的最小(或最大)元素放到未排序序列的开始。
★ 这个过程一直进行到整个数组的所有元素都被排为有序状态

1.2、代码实现

此处可以进行一个小的优化,同时找最小值与最大值,但是有一个细节需要注意,先上代码。

此处还需要交换元素,所以提前封装一个交换函数。

void Swap(int* p1, int* p2)
{int tmp = *p1;*p1 = *p2;*p2 = tmp;
}
void SelectSort(int a[], int n)
{int begin = 0;int end = n - 1;while (begin < end){int maxi = begin;//找最大值的下标int mini = begin;//找最小值的下标for (int i = begin + 1; i <= end; i++){if (a[i] < a[mini]){mini = i;}if (a[i] > a[maxi]){maxi = i;}}Swap(&a[begin], &a[mini]);Swap(&a[end], &a[maxi]);begin++;end--;}
}

★ 首先初始化两个索引beginend,分别代表当前未排序序列的开始和结束位置。

★ 进入一个循环,条件是begin < end,确保在数组中还有未排序的元素。

★ 遍历一遍序列,找到最大元素和最小元素的下标。

★ 将最小元素与序列的始端交换,最大元素与序列的尾端交换。

更新begin与end。

思考一下上面写的代码有没有问题呢???

答案是有问题的,因为这里我们是首先进行最小元素与首位置更换,再进行最大元素与末尾更换,如果我的最大元素就在首位置就会有问题,如下图:

如果最大值就在第一个位置时需要更新最大值的下标!!! 

正确的代码如下:

void Swap(int* p1, int* p2)
{int tmp = *p1;*p1 = *p2;*p2 = tmp;
}
void SelectSort(int a[], int n)
{int begin = 0;int end = n - 1;while (begin < end){int maxi = begin;//找最大值的下标int mini = begin;//找最小值的下标for (int i = begin + 1; i <= end; i++){if (a[i] < a[mini]){mini = i;}if (a[i] > a[maxi]){maxi = i;}}Swap(&a[begin], &a[mini]);//最大值的位置跟最小值重合//mini被换到maxi位置时  原本的最大值则是miniif (maxi == begin)maxi = mini;Swap(&a[end], &a[maxi]);begin++;end--;}
}

注意:

1.这里是对最初的选择排序进行优化,最小值最大值一起进行的。

2.当最大值被交换后,需要重新赋值。 


 1.3、代码测试

测试代码:

//测试选择排序
int main()
{int a[] = { 9,8,7,6,5,4,3,2,1,0 };//给一组数据int sz = sizeof(a) / sizeof(a[0]);//计算数组元素个数printf("排序前:\n");ArrayPrint(a, sz);SelectSort(a, sz);printf("排序后:\n");ArrayPrint(a, sz);return 0;
}

 测试结果:

1.4、时空复杂度分析

时间复杂度

最好、平均、最坏情况下的时间复杂度都是 O(n^2)。

原因在于,不管数组的初始顺序如何,选择排序都需要比较所有未排序的元素来找到最小(或最大)的元素,并执行这个过程 n-1 次(对于 n 个元素的数组)。每次选择操作需要比较的次数从 n-1 次减少到 1 次,总共的比较次数是 (n-1) + (n-2) + … + 1 = n(n-1)/2,这是一个二次函数,因此时间复杂度为 O(n^2)。

空间复杂度

选择排序是一种原地排序算法,除了输入数组外,它只需要有限的几个变量(比如,用于存储最小元素下标的变量和循环计数器)。因此,它的空间复杂度为常数空间O(1)。

选择排序的特性总结:

1. 选择排序思考非常好理解,但是效率不是很好。实际中很少使用。
2. 时间复杂度:O(N^2)
3. 空间复杂度:O(1)
4. 稳定性:不稳定

5. 复杂性:简单

总结


本篇博客就结束啦,谢谢大家的观看,如果公主少年们有好的建议可以留言喔,谢谢大家啦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/29354.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关键参数testab的生成过程及jsvmp算法学习

在上一篇《JS 算法学习之请求中的 testab 参数》中,我们介绍了如何学习生成关键参数testab,并使用WebSocket方式进行调用。本次将详细介绍通过浏览器开发者工具进行断点跟踪的思路以及相应的封控策略测试。 调试及分析 确定算法入口通过浏览器的开发者工具(如Chrome的F12功…

幂集(C++)

终其一生&#xff0c;你在追求什么&#xff1f; ——2024年6月16日11&#xff1a;56 题目描述 给定正整数n&#xff08;n≥1&#xff09;&#xff0c;给出求{1~n}的幂集&#xff0c;例如&#xff0c;n3时&#xff0c;{1&#xff0c;2&#xff0c;3}对应的幂集合为{{}&#xff…

FlowUs项目经理初体验

作为一名项目经理&#xff0c;FlowUs可以作为一个强大的工具来帮助我管理项目的所有方面&#xff0c;从规划到执行再到监控和回顾。 FlowUs息流是什么&#xff1f;FlowUs息流是一款集文档、多维表、文件夹等功能于一体的新一代知识管理与协作平台 以下是一些使用FlowUs作为项…

streamlit markdown里支持latex公式显示

参考&#xff1a; https://docs.streamlit.io/develop/api-reference/write-magic/st.write https://discuss.streamlit.io/t/streamlit-markdown-a-streaming-markdown-component-with-latex-mermaid-table-code-support/72187 也有独立支持的st.latex 接口单独显示公司&…

AI绘画Stable Diffusion 保姆级教程,让AI人物轻松打光的种方法,我不允许你还不会!

大家好&#xff0c;我是画画的小强 我们常常听到这样的观点&#xff1a;光影&#xff0c;如同摄影的精髓&#xff0c;为图像赋予难以抗拒的质感和情感深度。 用AI生成的图片为什么总是觉得比较“假”&#xff0c;主要还是光影不足&#xff01; 今天我将一一解析多种光影调控…

使用 final 修饰一个变量时,是引用不能变还是引用的对象不能变?

在 Java 中&#xff0c;使用 final 关键字修饰一个变量时&#xff0c;表示这个变量的引用不能改变&#xff0c;即一旦初始化之后&#xff0c;不能再指向其他对象。但是&#xff0c;这并不意味着引用所指向的对象本身是不可变的。该对象的内容仍然可以被修改。 详细解释 引用不…

RemObjects教程

File—Other…—RemObjects Data Abstract—ComboServer Step(1) 在出现的 NewRemObjects SDK Server 对话框中 Project Folder &#xff1a;文件存档路径 Project Name &#xff1a;工程名称 Also-Create a matching client application and a project group&#xff1a;在创…

C#——文件读取FileStream类详情

文件读取FileStream类 一个文件进行读写的时候&#xff0c;会变成一个文件流 FileStream类输入流 用于从文件进行读取文件。输出流&#xff0c;向文件写入的操作 FilleStream用于文件当中任何位置的读写 此文章借鉴与&#xff1a;C#教程&#xff08;非常详细&#xff09; Fil…

CentOS(Linux)中7-Zip工具的深度探索:p7zip的安装与应用

目录 前言 安装 7za 基本使用方法 解压文件 压缩文件或目录 其他常用选项 注意事项 前言 在CentOS Linux系统环境下&#xff0c;当提到高效的数据压缩与解压缩工具时&#xff0c;p7zip是一个不容忽视的选择。p7zip是7-Zip在Linux平台上的实现&#xff0c;提供了与Windows…

电脑怎么录制游戏视频?轻松捕捉每一帧精彩

随着游戏产业的蓬勃发展&#xff0c;越来越多的玩家不仅满足于在游戏世界中的探索与冒险&#xff0c;更希望将自己的游戏精彩瞬间记录下来&#xff0c;分享给更多的朋友。可是电脑怎么录制游戏视频呢&#xff1f;本文旨在为广大游戏爱好者提供一份详细的电脑游戏视频录制攻略&a…

Java 智慧工地监管平台源码 依托智慧工地平台,满足省、市级住建数据监管要求(微服务架构+Java+Spring Cloud +UniApp +MySql)

Java 智慧工地监管平台源码 依托智慧工地平台&#xff0c;满足省、市级住建数据监管要求 智慧工地是将互联网的理念和科技引入建筑工地&#xff0c;从施工现场源头抓起&#xff0c;最大程度的收集人员、安全、环境、材料等关键业务数据。通过结合物联网、大数据、互联网、云计…

spring data mongo MongoTemplate 查询最大值的数据

使用MongoTemplate查询最大值的数据&#xff0c;可以使用Query和Criteria类来构建查询条件。以下是一个示例&#xff1a; java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.mongodb.core.MongoTemplate; import org.spr…

AI绘画stable diffusion 模型介绍及下载、使用方法,超全的新手入门教程建议收藏!

大家好&#xff0c;我是画画的小强 今天我将继续分享AI绘画Stable Diffusion的模型、参数含义等&#xff0c;分享给各位朋友一起学习。 一、模型 Stable difusion 模型就是所谓的大模型&#xff0c;用来控制整个画面的风格走势的。 打开webui页面&#xff0c;可以看到大模型…

在Linux中如何解决程序崩溃的问题

一、背景 在Linux上的C/C环境如何调试程序崩溃问题&#xff1f;通常在这种情况&#xff0c;通过拿到出问题时产生的core文件&#xff0c;然后再利用gdb调试来看到出错时的程序栈信息。但某些特殊的情况&#xff0c;如不正确的系统设置或文件系统出现问题时&#xff0c;导致我们…

项目学习---Javaweb(超市订单管理系统)

知识点 MVC模型: 实现步骤:分为3级 1.M(Model) 持久层 代码与数据库进行交互的代码(Mybatis-dao层) 2.C(Control) 控制层 完成某项业务的具体操作过程(Controller层----Service层) 3.V(View) 视图层 一般指用户看到的内容(页面) 项目目录 .filter //过滤器 解决中文字符集…

【绝对有用】c++线程池相关技术点一

1.这段代码是在 C 中创建多个线程并启动它们。让我们逐步解析每个部分&#xff1a; for (size_t i 0; i < threadCount; i) {: • 这是一个 for 循环&#xff0c;从 i 0 开始&#xff0c;一直执行到 i 小于 threadCount 的时候。i 表示每次循环后将 i 加 1。threads.empl…

4、多分支判断 - 课件

一、基础知识 多分支判断的基本语法可以表示为: if (判断条件1) {// 如果判断条件1为真,执行这里的代码 } else if (判断条件2) {// 如果判断条件1为假且判断条件2为真,执行这里的代码 } else if (判断条件3) {// 如果判断条件1和判断条件2都为假且判断条件3为真,执行这里的代…

眼动研究实验设计方法

摘要 本文对基于实验室的眼动实验设计进行了总体回顾&#xff0c;并侧重于回顾实验程序和方法&#xff0c;从而为眼动追踪实验提供一个框架或背景。本文内容涵盖了基本的实验设计&#xff0c;这与实验心理学课本没有太大的区别&#xff0c;其中析因设计在眼动追踪研究中特别受…

day02 CSS基础

目录 CSS介绍 CSS使用方式 内联方式 内部样式表 外部样式表 CSS特性 优先级 选择器 元素选择器 id选择器 类选择器 派生选择器 子选择器 属性选择器 首个子元素 指定元素选择器 伪类选择器 文本 字体 列表 表格 背景 鼠标 border 宽高 box模型 元素水…

SpringCloudAlibaba组件集成

SpringCloudAlibaba组件集成 Nacos服务注册与发现 1.Nacos认识与安装 1.1.什么是Nacos Nacos和Eureka有着相同的能力&#xff0c;甚至更为强大&#xff0c;作为Dubbo 生态系统中重要的注册中心实现。官方对它有如下定义&#xff1a; Nacos致力于帮助您发现&#xff0c;配置…