排序算法分类及其稳定性

news/2024/12/21 21:48:21/

算法>排序算法可分为五类八种

类别

一、插入排序

1、直接插入排序 稳定

先对数组前两个元素进行比较和交换接着后面的元素依次作和前面的元素作比较和交换(插入)

2、希尔排序(shell排序) 不稳定

通过引入增量序列Ri 每次进行等距离Ri若干个元素的排序后再次进行R(i-1)<Ri的等距离元素排序 直至R(i-n)=1最后一次排序即可完成希尔排序

二、选择排序

1、直接选择排序 不稳定

先选出排序码最小的元素然后移入排序数组接着在剩下的元素中选出排序码最小的元素依次进行可得到一个有序序列

2、堆排序 不稳定

分为大根堆和小根堆,先建堆再移出堆顶元素再建堆的一个过程

三、交换排序

1、冒泡排序 稳定

先通过数组底部两个相邻元素(Xi和X(i-1))的比较和交换接着比较(X(i-2)和X(i-1))依次进行i的自减比较直到得到最小或最大元素 将其移出比较数组移入排序数组即可

2、快速排序(分治法) 不稳定

相当于二分查找的形式,将问题采用分治法的方式去解决,首先将数组首位元素确定为基准元素与末位元素比较,如果是顺序排序 则基准元素大于末位元素的话

基准元素和末位元素交换元素,且首指针+1尾指针不变 若基准元素小于末位元素的话则元素不交换首指针不变尾指针+1直到基准元素将原数组分隔为1个或多个数组然后再在剩余的数组里面采用递归的形式实现快速排序

四、归并排序 稳定

将问题分解区域化最终再合并处理

五、基数排序 稳定

采用个位排序、十位排序、百位排序等等依次的排序方式最终得出一个有序序列

排序时放入的数据结构相当于一个哈希表 索引为0-9


http://www.ppmy.cn/news/1536926.html

相关文章

SpringBoot实现:星之语明星周边销售平台开发指南

1系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#xff0c;这种种好处使得互联网成了信息传…

makefile的基本练习

假设有如下目录结构&#xff1a;&#xff08;目录结构图&#xff09; 完成以下操作&#xff1a; 1、通过纯命令编写Makefile文件&#xff0c;并发现使用纯命令的不足&#xff1b; 2、在Makefile中&#xff0c;添加变量&#xff0c;简化参数的重复书写&#xff1b; 3、尝试在多目…

【Java】集合中单列集合详解(一):Collection与List

目录 引言 一、Collection接口 1.1 主要方法 1.1.1 添加元素 1.1.2 删除元素 1.1.3 清空元素 1.1.4 判断元素是否存在 1.1.5 判断是否为空 1.1.6 求取元素个数 1.2 遍历方法 1.2.1 迭代器遍历 1.2.2 增强for遍历 1.2.3 Lambda表达式遍历 1.2.4 应用场景 二、…

Win32 API 控制台鼠标操作、坐标获取与相关函数介绍

Win32 API 控制台鼠标操作、坐标获取与相关函数介绍 一、前置介绍读取控制台输入缓冲区数据 ReadConsoleInput 函数控制台输入缓冲区中的输入事件 INPUT_RECORD 结构鼠标输入事件 MOUSE_EVENT_RECORD 结构更改输入模式 SetConsoleMode 函数 二、鼠标坐标获取(以下代码环境为 VS…

Vue vben admin开源库中table组件tips

table如何自定义表头和自定义内容 自定义表头直接使用tittle&#xff0c;自定义内容是customRender {title: (<span><img src{alvchat_avatar} style"width:20px;height:20px;vertical-align:bottom"></img>{t(routes.alerts.columnsAIReview)}<…

基于STM32的简易交通灯proteus仿真设计(仿真+程序+设计报告+讲解视频)

基于STM32的简易交通灯proteus仿真设计(仿真程序设计报告讲解视频&#xff09; 仿真图proteus 8.9 程序编译器&#xff1a;keil 5 编程语言&#xff1a;C语言 设计编号&#xff1a;C0091 **1.**主要功能 功能说明&#xff1a; 以STM32单片机和数码管、LED灯设计简易交通…

fiddler抓包18-1_导出jmeter脚本(jmx文件)

课程大纲 方法1 ① 下载2个扩展文件&#xff0c;FiddlerExtensions.dll和FiddlerExtensions.pdb&#xff0c;到Fiddler根目录中的“ImportExport”下&#xff0c;重启Fiddler。 下载链接: https://pan.baidu.com/s/1qtLoaiTd-VfHFb3UIPoSZw?pwdtwcu提取码: twcu ② Fiddler导…

世界职业院校技能大赛-软件测试赛项模拟案例参考分享

智慧金融探索&#xff1a;软件测试的未来 一、项目总体思路 本项目“智慧金融探索&#xff1a;软件测试的未来”&#xff0c;旨在通过深入研究和实践&#xff0c;探索软件测试的新高度。不仅追求精益求精的技术水平&#xff0c;更致力于将传统测试方法与现代技术相结合&#x…