📘
Introduction_to_Algorithms
  • Introduction
  • 第6章:堆排序
    • 练习题
    • 思考题
      • 6-3 Young
  • 第7章:快速排序
    • 练习题
    • 思考题
      • 7-6 对区间的模糊排序
  • 第8章:线性时间排序
    • 练习题
      • 8.3-4 O(n)时间内对[0..n^-1]之间的n个数排序
    • 思考题
      • 8-3 排序不同长度的数据项
  • 第9章 排序和顺序统计学算法导论
    • 练习题
      • 9.1-1
      • 9.3-3 快速排序-最坏时间O(nlgn)
      • 9.3-6 nlgk时间求k分位数
      • 9.3-8 求两个数组的中位数
    • 思考题
      • 9-2-c-带权中位数
  • 第10章:栈和队列
    • 10.1 栈和队列
      • 练习题
      • 10.1-2 用一个数组实现两个栈
      • 10.1-5 双端队列
    • 10.2 链表
      • 练习题
      • 10.2-5 环形链表实现字典操作INSERT、DELETE、SEARCH
    • 10.3 指针和对象实现
      • 练习题
      • 10.3-4 紧凑的多重数组
    • 思考题
  • 第11章 散列表
  • [第12章]
    • [笔记和代码]
      • 12-2 基数树
  • 第14章
    • 笔记和代码
      • 14.3-6 MIN GAP
  • 第15章:动态规划
    • 练习题
    • 思考题
      • 15-2 整齐打印
      • 15-3 编辑距离
  • 第20章:斐波那契堆
    • 练习题
    • 思考题
  • ACM解题报告
    • 1043 八数码问题
    • 1053 Entropy
    • 1114 Piggy-Bank 完全背包
    • 1133 catalan数二维变种
    • 1166 敌兵布阵
    • 1281 棋盘游戏 二分匹配与增广链
    • 1394 Minimum Inversion Number
    • 1394 用线段树求逆序数
    • 1787 欧拉函数之在线算法
    • 2438 三分查找
    • 2473 Junk-Mail Filter 并查集的删除
    • 2824 欧拉公式之打表算法
    • 2855 Fibonacci Check-up 矩阵的应用
    • 2642 Stars 二维树状数组
    • 2888 二维RMQ
    • 3033 分组背包之每组至少选一
    • 3307 A^B = C mod D,已知A,C,D,求解B
    • 3465 Life is a Line 用归并排序求逆序数
    • 3483 A Very Simple Problem 数论+矩阵的应用
    • 3518 后缀数组
    • 3579 中国剩余定理(ACM/不互质的情况)
    • 后缀数组
    • B-树
    • 排序算法总结
Powered by GitBook
On this page
  • 1.插入排序
  • 2.交换排序
  • 3.选择排序
  • 4.归并排序
  • 5.基数排序
  • 6.各种排序算法比较
  1. ACM解题报告

排序算法总结

1.插入排序

将一个记录插入到已排好序的有序表中,从而得到一个新的、记录数增1的有序表

(1)简单插入排序

(2)折半插入排序

(3)希尔排序:将整个待排记录序列分成若干个子序列分别进行插入排序,待整个序列基本有序时,再对全体记录进行一次直接插入排序

2.交换排序

(1)起泡排序:第i趟起泡排序中从L.r[1]到L.r[n-i+1]依次比较相邻两个记录的关键字,并在逆序时交换相邻记录,其结果是这n-i+1个记录中关键字最大的记录被交换到第n-i+1的位置上

(2)快速排序:选取一个记录作为枢轴,将所有关键字较它小的记录都安置在它的位置之前,将所有关键字较它大的记录都安置在它的位置之后,将序列分成两个子序列

3.选择排序

选取关键字最小的记录作为有序序列中的第i个记录

(1)简单选择排序

(2)堆选择排序:在输出堆顶后,以堆中最后一个元素替代之,自上向下进行调整,又建成一个堆,得到次小值。如此反复,便能得到一个有序序列

4.归并排序

将两个或两个以上的有序表组合成一个新的有序表

(1)2-路归并排序:将一维数组中前后相邻的两个有序序列归并为一个有序序列

5.基数排序

先对主关键字排序,再对次关键字排序

6.各种排序算法比较

平均时间

最坏时间

辅助内存

稳定性

简单选择排序

n^2

n^2

1

稳定

折半插入排序

n^2

n^2

1

不稳定

希尔排序

nlogn

n^2

1

不稳定

起泡排序

n^2

n^2

1

稳定

快速排序

nlogn

n^2

logn

不稳定

简单选择排序

n^2

n^2

1

稳定

堆选择排序

nlogn

nlogn

1

不稳定

2-路归并排序

nlogn

nlogn

n

稳定

基数排序

d(n+rd)

d(n+rd)

rd

稳定

(1)折半插入,虽然优化了比较次数,但是移动次数没变,因此时间复杂度不变

PreviousB-树

Last updated 3 years ago