C:数据结构---算法

1.1排序算法

稳定排序

不稳定排序

①冒泡排序(稳定)

比较相邻的元素。如果第一个比第二个大,就交换他们两个。对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对

②选择排序

在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。重复第二步,直到所有元素均排序完毕。

③插入排序

将第一待排序序列第一个元素看做一个有序序列,把第二个元素到最后一个元素当成是未排序序列。从头到尾依次扫描未排序序列,将扫描到的每个元素插入有序序列的适当位置。(如果待插入的元素与有序序列中的某个元素相等,则将待插入元素插入到相等元素的后面。)

④快速排序

从数列中挑出一个元素,称为 "基准"(pivot);

重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作;

递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序;

⑤归并排序
1.2查找算法

②③④⑤

相关推荐
随意起个昵称14 小时前
【贪心】选择尽量多的不相交区间
数据结构·算法
章小幽15 小时前
LeetCode-35.搜索插入位置
数据结构·算法·leetcode
j_xxx404_15 小时前
C++算法:一维/二维前缀和算法模板题
开发语言·数据结构·c++·算法
Book思议-16 小时前
顺序表和链表核心差异与优缺点详解
java·数据结构·链表
whn197718 小时前
在sqllog中排查达梦阻塞会话
数据结构
01二进制代码漫游日记18 小时前
C/C++中的内存区域划分
c语言·jvm·数据结构·学习
xiaoye-duck19 小时前
《算法题讲解指南:优选算法-链表》--51.两数相加,52.两两交换链表中的节点
数据结构·算法·链表
代码改善世界19 小时前
【数据结构】八大排序算法详解(C语言实现)|插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序
c语言·数据结构·排序算法
2501_9403152619 小时前
98验证二叉搜索树
java·数据结构·算法
仰泳的熊猫19 小时前
题目2266:蓝桥杯2015年第六届真题-打印大X
数据结构·c++·算法·蓝桥杯