| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> Python知识库 -> python每日算法 | 图文结合详解快速排序,手撕快排代码! -> 正文阅读 |
|
[Python知识库]python每日算法 | 图文结合详解快速排序,手撕快排代码! |
??创作不易,来了的客官点点关注,收藏,订阅一键三连?😜?? 前言程序=数据结构+算法,算法是数学理论和工程实现的杂糅,是一个十分有趣神奇的学问。搞懂算法用另一种视角看编程,又会是一种全新的感受,如果你也在学习算法,不妨跟主任萌新超差一起学习,拿下算法! 系列文章目录python每日算法 | 图文挑战十大排序算法DAY1,再也不用担心面试官问冒泡、选择、插入排序! python每日算法 | 实现四大查找算法,生动形象,保证一看就会! python每日算法 | 算法的起步与递归算法(汉诺塔问题) 概述本期的内容将介绍十大排序算法之快速排序,通过本期内容你不仅能知道他们的代码如何用python实现,还将此时快速排序与冒泡排序的效率比较等等!再也不用担心面试官问快排是什么呢!? 目录超超python每日算法思维导图快速排序什么是快速排序??快速排序(quick sort)使用分治法(Divide and conquer)策略来把一个序列(list)分为较小和较大的2个子序列,然后递归地排序两个子序列。 步骤为: ①挑选基准值:从数列中挑出一个元素,称为"基准"(pivot) ②分割:重新排序数列,所有比基准值小的元素摆放在基准前面,所有比基准值大的元素摆在基准后面(与基准值相等的数可以到任何一边)。在这个分割结束之后,对基准值的排序就已经完成 ③递归排序子序列:递归地将小于基准值元素的子序列和大于基准值元素的子序列排序。 递归到最底部的判断条件是数列的大小是零或一,此时该数列显然已经有序。 举例说明快速排序的思路 首先需要取一个元素P(第一个元素),使元素归位;随后列表被P分成两部分,左边的都比P小,右边的都比P大,随后递归完成排序。 如何选取基准值? 选取基准值有数种具体方法,此选取方法对排序的时间性能有决定性影响。 代码讲解快速排序算法的框架
那么快速排序的关键就在于如何设置基准值,即框架内的partition函数? 举例说明: 有如下列表 第一步:我们先存取“5”的位置,此时“5”的位置空出来,随后从左边和右边开始与“5”比较; 第二步:从最右边的位置的元素与“5”比较,如果比“5”大那么不动,发现比“5”小的(“2”)则放到刚刚空出来的“5”的位置; ?第三步:移动了“2”之后原来“2”的位置就空出来,则从当前“2”的位置(左边)开始查找,将比“5”大的数(7)移动到原先“2”的位置; ?第四步:重复第二到三步,直到左右的位置重合,即为“5”最终存放的位置 以上便是partition函数的思路(可能有点难理解) 实现快速排序算法代码
快速排序的效率快速排序的时间复杂度:O(nlogn)? (一层的复杂度是logn,总共n层) 快速排序函数与冒泡排序的效率比较
快速排序的缺点快速排序出现最糟糕情况时,例如列表从的元素是从10000到1,则突破了计算的最大深度,且复杂度达到了O(n2),空间复杂度也达到了O(n)。 此时可以通过调整运算的最大深度来进行运算(import sys --> sys.setrecursionlimit(100000)),但仍然运算的时间会变长,那么如何修改呢? 此时可以通过修改基准值位置随机取来调整,这样虽然不可以完全避免最坏情况,但是最坏情况的概率会降低。 十大排序之四大排序总结稳定性说明: 3 2 1 2 4 稳定的排序可以保证左右两边的2的位置不变; 当我们换成字典来看时: {"name":'a',"age":18} {"name":'b',"age":19} {"name":'a',"age":20} 如果按字母排序,稳定的排序,两个‘a’的位置不会改变 总的来说,挨个移动比较的排序算法为稳定的排序。 代码的复杂度:代表代码难不难写,应个人能力和主观感受而定。 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/15 13:54:24- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |