[DS+Algo] 006 两种简单排序及其代码实现
1. 快速排序 QuickSort
- 又称划分交换排序(partition-exchange sort)
- 通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要
- 然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行
1.1 步骤
- 从数列中挑出一个元素,称为"基准"(pivot)
- 排序数列,元素比基准值小的元素放到基准前面,所有比基准值大的元素放到基准后面
- 相同的数两边都能放,统一就好
- 在这个分区结束之后,该基准就处于数列的中间位置(其实就是它最终的位置)
- 这个称为分区(partition)操作
- 递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序
- 递归出口:数列的大小是零或一
- 也就是已经被排序好了
- 因为在每次的迭代(iteration)中,它至少会把一个元素摆到它最后的位置去
1.2 性能分析
- 最优时间复杂度:O(nlogn)
- 最坏时间复杂度:O(n2)
- 稳定性:不稳定
1.3 Python 代码示例
- 快排版本不唯一
- 这个只能算是快排的思路,比较费空间
from random import randrange
def quick_sort(lst):
n = len(lst)
if n <= 1:
return lst
pivot = lst[-1]
front, rear = [], []
for i in range(n-1):
if lst[i] < pivot:
front.append(lst[i])
else:
rear.append(lst[i])
return quick_sort(front) + [pivot] + quick_sort(rear)
if __name__ == "__main__":
lst = [randrange(10, 100) for _ in range(10)]
print(">>> before sort:", lst)
new_list = quick_sort(lst)
print(">>> after sort: ", new_list)
- 改进后的快排
from random import randrange
def quick_sort(lst, start, stop):
if stop <= start:
return
pivot = lst[stop]
low, high = start, stop
while low < high:
while low < high and lst[low] < pivot:
low += 1
lst[high] = lst[low]
while low < high and pivot <= lst[high]:
high -= 1
lst[low] = lst[high]
lst[low] = pivot
quick_sort(lst, start, low-1)
quick_sort(lst, low+1, stop)
if __name__ == "__main__":
lst = [randrange(10, 100) for _ in range(10)]
print(">>> before sort:", lst)
quick_sort(lst, 0, len(lst)-1)
print(">>> after sort: ", lst)
2. 归并排序 MergeSort
2.1 步骤
- 先说出口:当数列中的元素小于等于 1 时,即可退出
- 将数列对半分开
- 左边递归地排序
- 右边递归地排序
- 将左右两边合并
2.2 性能分析
- 最优时间复杂度:O(nlogn)
- 最坏时间复杂度:O(nlogn)
- 稳定性:稳定
2.3 Python 代码示例
from random import randrange
def merge_sort(lst):
n = len(lst)
if n <= 1:
return lst
mid = n // 2
left = merge_sort(lst[:mid])
right = merge_sort(lst[mid:])
return merge(left, right)
def merge(left, right):
L, R = 0, 0
result = []
nL, nR = len(left), len(right)
while L < nL and R < nR:
if left[L] < right[R]:
result.append(left[L])
L += 1
else:
result.append(right[R])
R += 1
if L < nL:
result += left[L:]
if R < nR:
result += right[R:]
return result
if __name__ == "__main__":
lst = [randrange(10, 100) for _ in range(10)]
print(">>> before sort:", lst)
sorted_list = merge_sort(lst)
print(">>> after sort: ", sorted_list)
[DS+Algo] 006 两种简单排序及其代码实现的更多相关文章
- [DS+Algo] 005 三种简单排序及其代码实现
目录 1. 冒泡排序 BubbleSort 1.1 算法描述 1.2 性能分析 1.3 Python 代码实现 2. 选择排序 SelectionSort 2.1 算法描述 2.2 选择排序的主要优点 ...
- 两种简单实现菜单高亮显示的JS类(转载)
两种简单实现菜单高亮显示的JS类 近期在写一个博客管理后台的前端,涉及在同一页面两种高亮显示当前菜单的需求.记得当年写静态页时,为了实现高亮都是在每个页面加不同的样式,呵.高亮显示我觉得对于web ...
- GIT将本地项目上传到Github(两种简单、方便的方法)
GIT将本地项目上传到Github(两种简单.方便的方法) 一.第一种方法: 首先你需要一个github账号,所有还没有的话先去注册吧! https://github.com/ 我们使用git需要先安 ...
- Java执行shell脚本并返回结果两种方法的完整代码
Java执行shell脚本并返回结果两种方法的完整代码 简单的是直接传入String字符串,这种不能执行echo 或者需要调用其他进程的命令(比如调用postfix发送邮件命令就不起作用) 执行复杂的 ...
- Visual Studio写的项目在 IIS 服务器上运行的两种简单方法
首先需要PC上开启了IIS服务,相关方法网上很多,也很简单 第一种:直接在项目中操作 1.创建一个项目,然后右击选中项目,右击,单击属性,打开项目属性标签页面 如图,选择Web标签,在服务器栏目中选中 ...
- Gradle实现的两种简单的多渠道打包方法
本来计划今天发Android的官方技术文档的翻译--<Gradle插件用户指南>的第五章的,不过由于昨天晚上没译完,还差几段落,所以只好推后了. 今天就说一下使用Gradle进行类似友盟这 ...
- Android 关于在ScrollView中加上一个ListView,ListView内容显示不完全(总是显示第一项)的问题的两种简单的解决方案
是这样的哈: 有这样一个需求: 1.显示一个界面,界面上有一个列表(ListView),列表上面有一个可以滚动的海报. 2.要求在ListView滚动的过程中,ListView上面的海报也可以跟着Li ...
- 两种简单的servlet实现反向代理
以下两种方法都需要引入jar包: <dependency> <groupId>org.mitre.dsmiley.httpproxy</groupId> <a ...
- Android传递Bitmap的两种简单方式及其缺陷
Android传递Bitmap的几种简单方式 一,通过Intent的Bundle. 比如有两个activity,A,B,从A进入B.先在A中将Bitmap写进去: Resources res=getR ...
随机推荐
- 关于mysql备份与恢复的操作
逻辑备份:将数据库的数据以逻辑的SQL语句的方式导出 mysqldump备份数据库 备份数据并带创建数据库 (含数据) mysqldump -uroot -p'123456' -B dbname &g ...
- JSP如何实现文件断点上传和断点下载?
核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...
- 微信浏览器video播放视频踩坑
video属性介绍 iOS的属性 playsinline On iPhone, video playsinline elements will now be allowed to play inlin ...
- 从零开始,编写简单的课程信息管理系统(使用jsp+servlet+javabean架构)
一.相关的软件下载和环境配置 1.下载并配置JDK. 2.下载eclipse. 3.下载并配置apache-tomcat(服务器). 4.下载MySQL(数据库). 5.下载Navicat for M ...
- localstorage sessionstorage cookie的区别
一.基本概念 Cookie cookie比较小,大小限制在4kb左右,是网景公司的前雇员 LouMontulli 在1993年3月的发明.它的主要用途有保存登录信息,比如你登录某个网站市场可以看到“记 ...
- shell脚本之case用法
你会经常发现自己在尝试计算一个变量的值,在一组可能的值中寻找特定值.在这种情形下, 你不得不写出很长的if-then-else语句,就像下面这样. $ cat test25.sh #!/bin/bas ...
- webpack安装大于4.x版本(没有配置webpack.config.js)
webpack安装大于4.x版本(没有配置webpack.config.js) webpack 输出参数-o 高版本 如果安装的webpack版本大于4+,还需要安装webpack-cli.在没有配 ...
- React Router学习笔记(转自阮一峰老师博客)
React Router是一个路由库,通过管理URL来实现组件切换和状态转变. 1.安装和使用 $ npm install -S react-router 在使用时,作为React组件导入 impor ...
- Mybaits 运行原理流程时序图
1 .初始化sqlsessionFactory 2openSession 3.getMapper返回接口的代理对象 包含了SqlSession对象 4.查询流程
- OpenCV学习笔记(1)
一.读入图像 使用cv2.imread()读入图像,图像应该在此程序的工作路径,第二个参数是告诉函数应该如何读取这幅图片 cv2.IMREAD_COLOR:读入一副彩色图像.图像的透明度会被忽略,这是 ...