【C语言】深入解析选择排序

文章目录

        • 什么是选择排序?
        • 选择排序的基本实现
        • 代码解释
        • 选择排序的优化
        • 选择排序的性能分析
        • 选择排序的实际应用
        • 结论

在这里插入图片描述

在C语言编程中,选择排序是一种简单且直观的排序算法。尽管它在处理大型数据集时效率不高,但由于其实现简单,常常用于教学和简单应用中。本文将详细介绍选择排序算法,包括其定义、实现、优化方法和性能分析,帮助读者深入理解这一经典算法。

什么是选择排序?

选择排序(Selection Sort)是一种基于比较的排序算法。其基本思想是每次从未排序部分中选出最小(或最大)的元素,将其放在已排序部分的末尾。重复这一过程,直到所有元素都排序完成。

选择排序的基本实现

以下是选择排序的基本实现代码:

#include <stdio.h>// 交换两个元素的值
void swap(int* a, int* b) {int t = *a;*a = *b;*b = t;
}// 选择排序函数
void selectionSort(int arr[], int n) {for (int i = 0; i < n-1; i++) {// 找到未排序部分的最小元素int min_idx = i;for (int j = i+1; j < n; j++) {if (arr[j] < arr[min_idx])min_idx = j;}// 交换最小元素和未排序部分的第一个元素swap(&arr[min_idx], &arr[i]);}
}// 打印数组函数
void printArray(int arr[], int size) {for (int i = 0; i < size; i++)printf("%d ", arr[i]);printf("\n");
}// 主函数
int main() {int arr[] = {64, 25, 12, 22, 11};int n = sizeof(arr)/sizeof(arr[0]);printf("未排序的数组: \n");printArray(arr, n);selectionSort(arr, n);printf("排序后的数组: \n");printArray(arr, n);return 0;
}
代码解释
  1. 交换函数swap

    • 用于交换两个元素的值。
  2. 选择排序函数selectionSort

    • 使用一个for循环遍历数组,每次选出未排序部分的最小元素,并将其与未排序部分的第一个元素交换。
    • 内层循环用于找到未排序部分的最小元素索引min_idx
  3. 打印数组函数printArray

    • 遍历数组并打印每个元素,便于查看排序结果。
  4. 主函数main

    • 初始化一个整数数组并计算其大小。
    • 调用selectionSort函数对数组进行排序。
    • 打印排序前后的数组。
选择排序的优化

选择排序的基本实现已经非常简单直接,但仍有一些优化方法可以稍微提升其性能:

  1. 减少交换操作

    • 在内层循环中仅记录最小元素的索引,外层循环结束后再进行交换操作,这样可以减少不必要的交换操作。

    优化代码示例:

    void selectionSort(int arr[], int n) {for (int i = 0; i < n-1; i++) {int min_idx = i;for (int j = i+1; j < n; j++) {if (arr[j] < arr[min_idx])min_idx = j;}// 仅在需要时才进行交换if (min_idx != i)swap(&arr[min_idx], &arr[i]);}
    }
    
  2. 双向选择排序

    • 双向选择排序在每一轮中同时选出最小值和最大值,并分别放置在未排序部分的两端,从而减少排序轮数。

    优化代码示例:

    void selectionSort(int arr[], int n) {for (int i = 0; i < n/2; i++) {int min_idx = i;int max_idx = i;for (int j = i+1; j < n-i; j++) {if (arr[j] < arr[min_idx])min_idx = j;if (arr[j] > arr[max_idx])max_idx = j;}// 交换最小值到未排序部分的起始位置if (min_idx != i)swap(&arr[min_idx], &arr[i]);// 如果最大值是起始位置的元素,需要更新max_idxif (max_idx == i)max_idx = min_idx;// 交换最大值到未排序部分的末尾位置if (max_idx != n-i-1)swap(&arr[max_idx], &arr[n-i-1]);}
    }
    
选择排序的性能分析

选择排序的时间复杂度为 O ( n 2 ) O(n^2) O(n2),这是因为每次选出最小(或最大)元素都需要遍历未排序部分。无论最坏、最好还是平均情况,选择排序的时间复杂度都是 O ( n 2 ) O(n^2) O(n2)。虽然选择排序的时间复杂度较高,但由于其简单性,在处理小型数据集时仍有一定的应用价值。

选择排序的空间复杂度为 O ( 1 ) O(1) O(1),因为它只需要常数级别的额外空间来存储临时变量。选择排序是一个不稳定的排序算法,因为相同元素的相对位置可能会改变。

选择排序的实际应用

选择排序由于其简单性和易实现性,在以下几种情况下非常有用:

  1. 教学和演示

    • 选择排序算法简单直观,非常适合作为初学者学习排序算法的入门教材。
  2. 小型数据集

    • 在处理小型数据集时,选择排序的性能足够,而且实现简单。
  3. 需要简单实现的场景

    • 选择排序的实现代码简洁明了,适合在需要快速实现排序功能的场景中使用。
结论

选择排序是C语言中一种简单且直观的排序算法,其实现简单且易于理解。尽管选择排序的效率较低,但通过减少不必要的交换操作和双向选择排序等方法,可以在一定程度上提升其性能。在学习和使用选择排序时,了解其优缺点以及适用场景,能够帮助我们更好地选择和使用排序算法。希望本文能帮助读者深入理解选择排序,并在实际编程中灵活应用。

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

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

相关文章

基于协同过滤混合算法的餐饮推荐系统设计与实现

基于协同过滤混合算法的餐饮推荐系统设计与实现 Design and Implementation of Restaurant Recommendation System Based on Hybrid Collaborative Filtering Algorithm 完整下载链接:基于协同过滤混合算法的餐饮推荐系统设计与实现 文章目录 基于协同过滤混合算法的餐饮推荐…

牛客TOP101:反转链表

文章目录 1. 题目描述2. 解题思路3. 代码实现 1. 题目描述 2. 解题思路 简单粗暴的写法&#xff0c;就是从头到尾挨个将所有结点的指向翻转即可。需要注意的是&#xff0c;翻转之后会失去原有指向的结点&#xff0c;所以需要提前保存。   具体做法就是&#xff0c;使用cur标记…

面试必备!Redis面试题合集

目录 1.Redis简介 2. 分布式缓存常见的技术选型方案有哪些? 3. 说一下 Redis 和 Memcached 的区别和共同点 4. 缓存数据的处理流程是怎样的? 5. 为什么要用 Redis/为什么要用缓存? 6. Redis 常见数据结构以及使用场景分析 6.1. string 6.2. list 6.3. hash 6.4. s…

Spring源码注解篇二:手写@Component注解

Component注解的功能 在Spring框架中&#xff0c;Component 注解是一个核心特性&#xff0c;用于自动检测类并将其注册为Spring应用上下文中的Bean。这大大简化了Bean的配置过程&#xff0c;使得开发者能够通过注解的方式快速地将类标记为组件&#xff0c;并由Spring容器进行管…

硬件检测工具 | CPU-Z v2.10.0 官方中文绿色版

软件简介 CPU-Z是一款广受欢迎的硬件检测工具&#xff0c;主要用于收集电脑处理器的详细信息。这款软件能够提供关于CPU的详细数据&#xff0c;包括处理器名称、编号、代号、进程和缓存等信息。此外&#xff0c;CPU-Z还能实时监测每个内核的内部频率和内存频率&#xff0c;以及…

【洛谷B3644】【模板】拓扑排序 / 家谱树 解题报告

洛谷B3644 - 【模板】拓扑排序 / 家谱树 题目描述 有个人的家族很大&#xff0c;辈分关系很混乱&#xff0c;请你帮整理一下这种关系。给出每个人的后代的信息。输出一个序列&#xff0c;使得每个人的后辈都比那个人后列出。 输入格式 第 1 1 1 行一个整数 N N N&#xf…

Java字节流的输入输出

Java字节流的输入输出指的是使用Java中的字节流来进行数据的读取和写入操作。字节流是以字节为单位进行读写操作的&#xff0c;常用于处理二进制数据或者字符数据。 Java中常用的字节流类有InputStream和OutputStream。InputStream用于读取字节数据&#xff0c;OutputStream用…

【运维项目经历|037】MFS-Scale分布式对象存储系统部署与优化项目

🍁博主简介: 🏅云计算领域优质创作者 🏅2022年CSDN新星计划python赛道第一名 🏅2022年CSDN原力计划优质作者 ​ 🏅阿里云ACE认证高级工程师 ​ 🏅阿里云开发者社区专家博主 💊交流社区:CSDN云计算交流社区欢迎您的加入! 目录 项目名称 项目背景 项目目标 …

如何在项目中打印sql和执行的时间

目标&#xff1a;打印DAO方法中sql和执行的时间 一种方式是去实现Mybatis的拦截器Interceptor &#xff0c;比较麻烦&#xff1b; 这里介绍一种比较简单的实现方式&#xff1b; 1、如何打印sql&#xff1f; 配置文件加这个可以打印出com.zhenhui.ids.busi.watch包下执行的sq…

c++包管理器

conan conan search&#xff0c;查看网络库 conan profile detect&#xff0c;生成缓存信息conan new cmake_exe/cmake_lib&#xff0c;创建cmakelists.txtconan install .&#xff0c;执行Conanfile.txt中的配置&#xff0c;生成相关的bat文件 项目中配置Conanfile.txt(或者…

ImportError: DLL load failed while importing _swigfaiss: 找不到指定的模块。

ImportError: DLL load failed while importing _swigfaiss: 找不到指定的模块 这个错误通常是由于系统中缺少某些必要的动态链接库&#xff08;DLL&#xff09;文件&#xff0c;或者由于与当前环境中的库版本不兼容导致的。以下是一些解决这个问题的步骤&#xff1a; 方法一&…

linux高级编程(sqlite数据库调用)

数据库 1、分类&#xff1a; 大型 中型 小型 ORACLE MYSQL/MSSQL SQLITE DBII powdb 关系型数据库 2、名词&#xff1a; DB 数据库 select update database DBMS 数据库管理系统 MIS 管理…

tessy 集成测试:小白入门指导手册

目录 1,创建集成测试模块且分析源文件 2,设置测试环境 3,TIE界面设置相关函数 4,SCE界面增加用例 5,编辑数据 6,用例所对应的测试函数序列 7,添加 work task 函数 8,为测试场景添加函数 9,为函数赋值 10,编辑时间序列的数值 11,执行用例 12,其他注意事项…

《昇思25天学习打卡营第2天|初学教程/快速入门》

文章目录 快速入门处理数据集网络构建模型训练保存模型加载模型 快速入门 通过MindSpore的API来快速实现一个简单的深度学习模型。 MindSpore 是华为推出的一个全场景深度学习框架&#xff0c;它旨在实现易开发、高效执行和全场景覆盖的目标。这个框架支持云、边缘以及端侧场…

零基础STM32单片机编程入门(十四) DS18B20温度传感器模块实战含源码

文章目录 一.概要二.DS18B20主要性能参数三.DS18B20温度传感器内部框图四.DS18B20模块原理图五.DS18B20模块跟单片机板子接线和通讯时序1.单片机跟DS18B20连接示意图2.单片机跟DS18B20通讯流程与时序3.通讯流程中的9个数据字节内容格式4.温度数据寄存器LSB/MSB格式 六.STM32单片…

ROS2入门到精通—— 1-3 ROS1移植到ROS2系统梳理

ROS2同一功能包只能同时包含Python或者C一种 1 ROS1 && ROS2 CMakeList.txt ROS1中CMakeLists.txt架构如下&#xff1a; cmake_minimum_required() #CMake的最低版本号project() #项目名称find_package() #找到编译需要的其他CMake/Catkin package catkin_py…

【HarmonyOS】鸿蒙中如何获取用户相册图片?photoAccessHelper.PhotoViewPicker

【HarmonyOS】鸿蒙中如何获取用户相册图片&#xff1f;photoAccessHelper.PhotoViewPicker 前言 有同学私聊我说&#xff0c;之前的博客文章提到的没有HarmonyOS白名单帐号&#xff0c;如何在OpenHarmony Gitee开发仓里学习API接口。需要注意一个点&#xff0c;默认看到的文档…

图、图的遍历、最小生成树、最短路径

0、图的概念 **图:**是由顶点集合及顶点间的关系组成的一种数据结构&#xff1a;G (V&#xff0c; E)&#xff0c;其中&#xff1a; 顶点集合V {x|x属于某个数据对象集}是有穷非空集合&#xff1b;边的集合E {(x,y)|x,y属于V}或者E {|x,y属于V && Path(x, y)}是顶…

浅学三次握手

数据要完成传输&#xff0c;必须要建立连接。由于建立TCP连接的过程需要来回3次&#xff0c;所以&#xff0c;将这个过程形象的叫做三次握手。 结合上面的图来看更清楚。 先说三次握手吧&#xff0c;连接是后续数据传输的基础。就像我们打电话一样&#xff0c;必须保证我和对方…

在 PostgreSQL 里如何实现数据的实时监控和性能瓶颈的快速定位?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 在 PostgreSQL 里如何实现数据的实时监控和性能瓶颈的快速定位一、数据实时监控的重要性二、PostgreSQ…