当前位置: 首页 > news >正文

数据结构之深入理解简单选择排序:原理、实现与示例(C,C++)

文章目录

    • 一、简单选择排序原理
    • 二、C/C++代码实现
    • 总结:

在这里插入图片描述


在计算机科学中,排序算法是一种非常基础且重要的算法。简单选择排序(Selection Sort)作为其中的一种,因其实现简单、易于理解而受到许多初学者的喜爱。本文将详细介绍简单选择排序的原理、实现过程,并通过C/C++代码示例来加深理解。

一、简单选择排序原理

简单选择排序的基本思想是:首先在未排序序列中找到最小(或最大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(或最大)元素,然后放到已排序序列的末尾。以此类推,直到所有元素均排序完毕。

算法步骤:

  1. 初始状态:给定待排序的序列 arr,包含 n 个元素。
  2. 第一次遍历:从第一个元素开始,依次与后面的元素比较,找到最小的元素,将其与第一个元素交换位置。
  3. 第二次遍历:从第二个元素开始,依次与后面的元素比较,找到最小的元素,将其与第二个元素交换位置。
  4. 重复步骤2和步骤3,直到倒数第二个元素和最后一个元素比较完毕。

这样经过 n-1 次遍历后,整个序列就排好序了。

算法分析:

  1. 时间复杂度:选择排序的时间复杂度为 O(n^2),其中 n 是数据元素的个数。虽然时间复杂度比较高,但是它的实现思路简单,适合于数据量较小的情况。
  2. 空间复杂度:选择排序是一种原地排序,空间复杂度为 O(1)。
  3. 稳定性:简单选择排序是一种不稳定的排序算法,即可能改变相同元素的相对顺序。

二、C/C++代码实现

以下是简单选择排序的C代码实现:

#include <stdio.h>void selectionSort(int arr[], int n) {int i, j, min_index, temp;for (i = 0; i < n - 1; i++) {// 初始化最小值索引min_index = i;// 遍历未排序序列,找到最小值索引for (j = i + 1; j < n; j++) {if (arr[j] < arr[min_index]) {min_index = j;}}// 交换最小值与未排序序列的第一个元素if (min_index != i) {temp = arr[i];arr[i] = arr[min_index];arr[min_index] = temp;}}
}int main() {int arr[] = {64, 25, 12, 22, 11};int n = sizeof(arr) / sizeof(arr[0]);selectionSort(arr, n);printf("Sorted array: \n");for (int i = 0; i < n; i++) {printf("%d ", arr[i]);}printf("\n");return 0;
}

代码解析

  1. 函数selectionSort接收一个整型数组arr和数组长度n作为参数。
  2. 外层循环控制排序的趟数,共进行n-1趟排序。
  3. 内层循环寻找未排序序列中的最小值索引。
  4. 如果找到的最小值索引不是当前外层循环的起始索引,则交换这两个位置的元素。
  5. 主函数main中,定义了一个待排序的数组,调用selectionSort函数进行排序,并输出排序后的结果。

下面是用 C++ 编写的简单选择排序的示例代码:

#include <iostream>void selectionSort(int arr[], int n) {int i, j, minIndex;for (i = 0; i < n - 1; i++) {// 找到未排序部分的最小元素minIndex = i;for (j = i + 1; j < n; j++) {if (arr[j] < arr[minIndex]) {minIndex = j;}}// 将最小元素与当前位置交换if (minIndex != i) {std::swap(arr[i], arr[minIndex]);}}
}int main() {int arr[] = {64, 25, 12, 22, 11};int n = sizeof(arr) / sizeof(arr[0]);std::cout << "Original array:" << std::endl;for (int i = 0; i < n; i++) {std::cout << arr[i] << " ";}std::cout << std::endl;selectionSort(arr, n);std::cout << "Sorted array:" << std::endl;for (int i = 0; i < n; i++) {std::cout << arr[i] << " ";}std::cout << std::endl;return 0;
}

解析示例代码:

  • selectionSort 函数实现了选择排序算法。外层循环控制待排序部分的起始位置,内层循环用来找到最小元素的索引。
  • std::swap 函数用于交换数组中的两个元素。
  • main 函数演示了如何使用 selectionSort 函数对数组进行排序,并输出结果。

结果:
运行上述代码,输出如下结果:

Original array:
64 25 12 22 11
Sorted array:
11 12 22 25 64

这证明了选择排序成功地将输入的数组从小到大进行了排序。

总结:

简单选择排序虽然在大数据量下效率不高,但它易于理解和实现,是理解排序算法基本思想的良好起点。在实际应用中,如果数据量较小或者对排序稳定性要求不高,选择排序可以作为一种简单有效的选择。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Feign自定义调用第三方接口并实现负载均衡
  • Ansible的脚本-----playbook剧本【下】
  • Mac m1安装 MongoDB 7.0.12
  • 一款好看的某社区/空间/论坛/官方软件下载页源码
  • JDBC(Java访问数据库)
  • 【ESP01开发实例】-驱动OLED SSD1306显示屏
  • Web安全:Web体系架构存在的安全问题和解决方室
  • 视觉巡线小车(STM32+OpenMV)——总结
  • Dify中HTTP请求节点的常见操作
  • 数据url
  • C++中 cin、cin.get()、cin.getline()、getline() 的区别
  • Blender材质-PBR与纹理材质
  • scratch聊天机器人 2024年6月scratch四级 中国电子学会图形化编程 少儿编程等级考试四级真题和答案解析
  • sql server 连接报错error 40
  • 基于内容的音乐推荐网站/基于ssm的音乐推荐系统/基于协同过滤推荐的音乐网站/基于vue的音乐平台
  • AzureCon上微软宣布了哪些容器相关的重磅消息
  • extjs4学习之配置
  • Go 语言编译器的 //go: 详解
  • Golang-长连接-状态推送
  • k个最大的数及变种小结
  • STAR法则
  • supervisor 永不挂掉的进程 安装以及使用
  • WePY 在小程序性能调优上做出的探究
  • XML已死 ?
  • 从setTimeout-setInterval看JS线程
  • 猴子数据域名防封接口降低小说被封的风险
  • 看完九篇字体系列的文章,你还觉得我是在说字体?
  • 七牛云假注销小指南
  • 融云开发漫谈:你是否了解Go语言并发编程的第一要义?
  • 探索 JS 中的模块化
  • 微信小程序实战练习(仿五洲到家微信版)
  • 原创:新手布局福音!微信小程序使用flex的一些基础样式属性(一)
  • MPAndroidChart 教程:Y轴 YAxis
  • Spring第一个helloWorld
  • 微龛半导体获数千万Pre-A轮融资,投资方为国中创投 ...
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • ​力扣解法汇总1802. 有界数组中指定下标处的最大值
  • # SpringBoot 如何让指定的Bean先加载
  • #android不同版本废弃api,新api。
  • #Linux(make工具和makefile文件以及makefile语法)
  • (02)Unity使用在线AI大模型(调用Python)
  • (ctrl.obj) : error LNK2038: 检测到“RuntimeLibrary”的不匹配项: 值“MDd_DynamicDebug”不匹配值“
  • (Java入门)学生管理系统
  • (JS基础)String 类型
  • (安卓)跳转应用市场APP详情页的方式
  • (二)c52学习之旅-简单了解单片机
  • (十五)Flask覆写wsgi_app函数实现自定义中间件
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (一)基于IDEA的JAVA基础1
  • (转)淘淘商城系列——使用Spring来管理Redis单机版和集群版
  • (转载)在C#用WM_COPYDATA消息来实现两个进程之间传递数据
  • *++p:p先自+,然后*p,最终为3 ++*p:先*p,即arr[0]=1,然后再++,最终为2 *p++:值为arr[0],即1,该语句执行完毕后,p指向arr[1]
  • .form文件_SSM框架文件上传篇
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器