python算法-快速排序
快速排序:
学习快速排序,要先复习下递归:
递归的2个条件:
1. 函数自己调用自己
2.有一个退出的条件
练习:基于递归下一个函数,计算n!并且求出当n等于10的值。
n!=n * n-1*…..*1
#enconding = utf-8
def func(n):
if n<=1:
return 1
else:
return n*func(n-1)
print func(10)
结果:3628800
快速排序:也是基于递归的思想
核心思想:对于一个数组 12 23 3 4 56 21
快排是从里面随机选择一个数,如21,把所有小于这个数字的排在它的左边,把所有大于它的数排在右边。
用指针指明位置,遍历数组:j-> 0到4
用i表示下标i左边的都是小于21的,包括下标i
初始值 i=-1 -1是针对最小数刚好在最后一位的极端情况
初始值j=0 ,j控制遍历数组的下标。
用j去和21比较,如果大于21,则空过不处理;如果小于21:i要加1,把i和j指向的元素交换位置
手工排序:
i=-1 j=0
取出12,12<21-à i+1=0;i和j指向的元素交换位置,此时i=j=0,都是指向lista[0];j++
12 23 3 4 56 21
i=0,j=1
取出23,21 23>21,空过
12 23 3 4 56 21
i=0 ,j=2
取出3,21, 3<21-> i+1=1;i和j对应元素位置交换,lista[1],lista[2] =
12 3 23 4 56 21
i=1 j=3
取出4<21,i+1=2; i和j对应元素位置交换
12 3 4 23 56 21
i=1;j=4
取出56>21;空过
12 3 4 23 56 21
把下标i+1的元素和最后一个元素交换位置
12 3 4 21 56 23
这样,就完成了第一轮的排序。
为什么要选择最后一个数字呢?
很容易找到。其实选择哪一个最后的结果都是一样的。因此为了简单我们直接就取的最后一个数作为基准数字。
下面,我们来写出12 3 4 以及右子列表56 23快排一次后的结果
左: 3 4 12
右:23 56
快排程序:
1.对于listx调用快排
2.对于listx的左子列表12 3 4进行快排,对于listx的右子列表56 23进行快排
3.直到列表只有一个元素的时候,退出
#enconding = utf-8
def Quick_Sort(lista):
def pathSort(lista,sIndex,eIndex):#第一重排序
flag = lista[eIndex]
i = sIndex - 1
for j in xrange(sIndex,eIndex):
if lista[j]<flag:
i+=1
lista[i],lista[j] = lista[j],lista[i]
else:
pass
lista[eIndex],lista[i+1] = lista[i+1],lista[eIndex]
return i+1
def qSort(listb,sIndex,eIndex):
if sIndex >= eIndex: #如果开始位置大于等于起始位置,返回
return
middle = pathSort(listb,sIndex,eIndex)
#递归调用左子列表
qSort(listb,sIndex,middle-1)
#递归调用右子列表
qSort(listb,middle+1,eIndex)
qSort(lista,0,len(lista)-1)
return lista
if __name__ == '__main__':
print Quick_Sort([12,3,4,21,56,23])
变形练习1:修改成从大到小排列。
#enconding = utf-8
def Quick_Sort(lista):
def pathSort(lista,sIndex,eIndex):#第一重排序
flag = lista[eIndex]
i = sIndex - 1
for j in xrange(sIndex,eIndex):
if lista[j]>flag:
i+=1
lista[i],lista[j] = lista[j],lista[i]
else:
pass
lista[eIndex],lista[i+1] = lista[i+1],lista[eIndex]
return i+1
def qSort(listb,sIndex,eIndex):
if sIndex >= eIndex: #如果开始位置大于等于起始位置,返回
return
middle = pathSort(listb,sIndex,eIndex)
#递归调用左子列表
qSort(listb,sIndex,middle-1)
#递归调用右子列表
qSort(listb,middle+1,eIndex)
qSort(lista,0,len(lista)-1)
return lista
if __name__ == '__main__':
print Quick_Sort([12,3,4,21,56,23])
时间复杂度:
第一轮:做完快排后发现基准数是最大的一个,我们比较了n-1次,最后一个
第二轮:n-2次
第三轮:n-3次
…
第n-1轮:1次
1+2+3….+n-1 = n^2/2
时间复杂度为O(nlogn)
平均情况:
n
第一轮:n-1,排列出2个列表,确定了1个结点的位置
第二轮:n-3,排列出4个列表,确定了3个结点的位置
第三轮:n-7,排列出8个列表,确定了7个结点的位置
第四轮:n-15,排列 出16个列表,确定了15个结点的位置
…..
平均比较次数n-x
2^i-1
总共需要多少轮,才能完成快排?
2^1 + 2^2 +…..2^i-I = n
2*(1-2^i)/1 -2 –I =n
2^(i+1)-2-I =n
i+1 ~ logn
I ~ logn
log(n-x)
最终时间复杂度为 O(nlogn)
python算法-快速排序的更多相关文章
- Python算法:推导、递归和规约
Python算法:推导.递归和规约 注:本节中我给定下面三个重要词汇的中文翻译分别是:Induction(推导).Recursion(递归)和Reduction(规约) 本节主要介绍算法设计的三个核心 ...
- Python与快速排序
这个算法系列主要是自己学习算法过程中动手实践一下,写这个文章作为笔记和分享个人心得,如有错误请各位提出. 注:转载请说明出处 问题提出: 将以下数据升序排列:5, 2, 8, 6, 4, 9, 7, ...
- GitHub标星2.6万!Python算法新手入门大全
今天推荐一个Python学习的干货. 几个印度小哥,在GitHub上建了一个各种Python算法的新手入门大全,现在标星已经超过2.6万.这个项目主要包括两部分内容:一是各种算法的基本原理讲解,二是各 ...
- 安装Python算法库
安装Python算法库 主要包括用NumPy和SciPy来处理数据,用Matplotlib来实现数据可视化.为了适应处理大规模数据的需求,python在此基础上开发了Scikit-Learn机器学习算 ...
- python算法(一)
python算法(一) 一.求数x的因子 x=100 divisors=()#初始化空的元组 for i in range(1,x): if x%i==0: divisors=divisors+(i, ...
- Python算法与数据结构--求所有子数组的和的最大值
Python算法与数据结构--求所有子数组的和的最大值 玄魂工作室-玄魂 玄魂工作室秘书 玄魂工作室 昨天 题目:输入一个整形数组,数组里有正数也有负数.数组中连续的一个或多个整数组成一个子数组,每个 ...
- Python算法(含源代码下载)
关键字:Python Algorithms Python算法 Mastering Basic Algorithms in the Python Language 使用Python语言掌握基本算法 P ...
- 《Java算法》排序算法-快速排序
排序算法-快速排序: /** * 给定一个数组:按照从小到大排序. * 思路: * 1. 获取第一个数放入临时变量data,将大于data的数放右边,小于data的数放在左边. * 2. data左边 ...
- python算法题 python123网站单元四题目
目录 一:二分法求平方根 二:Collatz猜想 三:算24(只考虑满足,不考虑把所有情况找出来) 下面向大家介绍几个python算法题. 一:二分法求平方根 1.题目要求为 2.输入输出格式为 ...
随机推荐
- mybatis(错误) 项目启动时报“Result Maps collection already contains value forxxx”的解决方案
使用逆向工程生成代码时,一定要将原来的代码删除干净,如果覆盖的话,不是真正的覆盖,在原来的代码上增加重复的代码,导致出错
- #52. 【UR #4】元旦激光炮 (交互式题)
链接:http://uoj.ac/problem/52 刚刚越过绝境长城,只见天空中出现了炫目的光芒 —— 圣诞老人出现了. 元旦三侠立刻进入战斗.生蛋侠.圆蛋侠和零蛋侠分别有 na,nb,ncna, ...
- 数据库查询,显示为树形结构(easyui+SSM)
在实际项目上,有很多地方后台存了一个表,但是在显示查询的时候需要显示为树形结构. 本项目是easyui+SSM框架. 前台程序为: <!DOCTYPE html> <html> ...
- Android 麦克风录音带音量大小动态显示的圆形自定义View
1.所谓无图无真相,先上效果图.我们要实现的就是中间那个录音的按钮,周边会显示一圈音量大小的波形 2.VolumCircleBar继承自View,我们进行了自定义,代码如下 package com.r ...
- 用YII实现多重查询(基于tag)
场景: 有一个饭店表 restaurant,存放所有饭店记录.我需要一个功能,将饭店按照不同的条件进行多重查询.就象这样: 氛围:浪漫 / 商务会谈 / 茅草屋 菜系:川菜 / 鲁菜 / 家常菜. ...
- codevs 3096 流输入练习——寻找Sb.VI
时间限制: 1 s 空间限制: 16000 KB 题目等级 : 白银 Silver 题目描述 Description 已知某开放授权人员名叫Serb,由于经常修改各种数据,因此开发人员们都喊他SB ...
- dp 20190618
C. Party Lemonade 这个题目是贪心,开始我以为是背包,不过也不太好背包,因为这个L都已经是1e9了. 这个题目怎么贪心呢?它是因为这里有一个二倍的关系,所以说val[i]=val[i- ...
- jQuery备忘录
jquery 中遍历数组 var arr = [1,2,3,4,5] $.each(arr,function(i,j){ console.log(i,j) }) 结果 0 1 1 2 .... jQu ...
- winhex 中磁盘大小与偏移
下图为c盘(活动分区).上方base offset为相对于整个硬盘的字节偏移量.partition 1中信息包括c盘开始扇区,总扇区数.partition 2 信息为扩展分区开始扇区和扇区数.由 P1 ...
- 各种分布(distribution)
正态分布(Normal distribution),又名高斯分布(Gaussian distribution).若随机变量X服从一个数学期望为μ.方差为σ^2(标准差为σ)的正态分布,记为N(μ,σ^ ...