Python之排序算法:快速排序与冒泡排序
Python之排序算法:快速排序与冒泡排序
转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/7828610.html
入坑(简称IT)这一行也有些年头了,但自老师讲课提过排序算法后几乎再也没写过排序算法,当然这也没有什么问题,实际的排序大多是将数据从数据库取出来前在数据库中就已经做好排序了,当然这个排序是SQL范畴的,如果真的需要在代码中排序也有对应的工具类来处理,就比如有Java中有Array.sort()来排列Array(数组类型),功能虽说有限制,但也免去了撸码的时间,嗯,不用写的大好处就是减少了开发时间,当然也增加了喝咖啡、网购的时间~

闲言多废话,先展示下快速排序的动态图再出代码,方便理解:

(上图是从维基百科中抓取的,包括本节所讲所的冒泡排序也是维基百科的)
嗯,酷酷的时间到了
,先我大概讲下快速排序:
A>先取一个数(一般是第一个数)作为参照的基准值
B>将待排序的数组分两边,一左一右分别指向数组的两边
C>左右两边分别向中间移,所指的数值大于基准值的向基准值右边放(如果是右边所指的值就挪动指向的位置,值不动),左边也一样
D>将基准位置两边的值分别排序(一般是递归调用)
好了,以上大概就是快速排序的的一半步骤,如有不懂之处,建议顺着代码来推测快速排序的整个过程,并不难
:
#!/usr/bin/env Python
#快速排序法
def quickSort(arr,_l,_r):
l,r,t=_l,_r,0
if l <= r:
t=arr[_l] #基准参数
while(l<r):
#当右边的值大于基准参数时,右值向左挪一(位置和值)
while l<r and arr[r]>=t:
r=r-1
arr[l]=arr[r] #右值挪到左值的位置
# 当左边的值小于基准参数时,右值向左挪一(位置和值)
while l<r and arr[l]<=t:
l=l+1
arr[r]=arr[l] #左值放入右值的位置
'''
当前一轮排完后将基准参数放入
将基准值左右两边的数值分别放入排序(递归调用)
'''
arr[r]=t #基准参数归位 quickSort(arr,_l,l-1) #基准位置左侧数据排序
quickSort(arr,l+1,_r) #基准位置右侧数据排序 i=[23,1,6,77,8,-11,100,11.1,99,24,21]
print ("排序之前")
print (i)
print ("排序之后")
quickSort(i,0,len(i)-1)
print (i) ==========以下是控制台输出=========== 排序之前
[23, 1, 6, 77, 8, -11, 100, 11.1, 99, 24, 21]
排序之后
[-11, 1, 6, 8, 11.1, 21, 23, 24, 77, 99, 100]
嗯~,快速排序完毕,先展示下冒泡排序的动态图,密集恐惧症者勿入
:


结合着图,冒泡排序的过程大致是这样子的:
A>取待排序数组中的一个值(一般是第一个值)作为基准值依次与其它所有数值比较
B>大于基准值的直接略过,小于基准值的与基准值交换位置
额~,还是用代码说话还是比较好一些吧~
#!/usr/bin/env Python #冒泡排序法
def bubleSort(arr):
for k in range(len(arr)):
temp = arr[k] #临时值,用于交换
for j in range(k+1,len(arr)):
'''
若值比基准值小则将基准值与当前值交换位置
'''
if arr[j]<arr[k]:
temp=arr[k]
arr[k]=arr[j]
arr[j]=temp
continue; #这里可有可无 i=[23,1,6,77,8,-11,100,11.1,99,24,21] print ("排序前")
print (i)
print ("排序后")
bubleSort(i)
print (i) ==========控制台输出============
排序前
[23, 1, 6, 77, 8, -11, 100, 11.1, 99, 24, 21]
排序后
[-11, 1, 6, 8, 11.1, 21, 23, 24, 77, 99, 100]
既然是Python,当然Python中对于数组也内置了一键排序算法:
ii=[23,1,6,77,8,-11,100,11.1,99,24,21]
ii.sort() #数组内置sort方法排序
print ("ii",ii)
ij=[23,1,6,77,8,-11,100,11.1,99,24,21]
ij=sorted(ij) #外部方法排序(相当于工具类)
print ("ij",ij)
既然Python已经提供了排序方法,还要白忙活一气,是不是很悲伤
Python之排序算法:快速排序与冒泡排序的更多相关文章
- Python实现排序算法之快速排序
Python实现排序算法:快速排序.冒泡排序.插入排序.选择排序.堆排序.归并排序和希尔排序 Python实现快速排序 原理 首先选取任意一个数据(通常选取数组的第一个数)作为关键数据,然后将所有比它 ...
- python实现排序算法 时间复杂度、稳定性分析 冒泡排序、选择排序、插入排序、希尔排序
说到排序算法,就不得不提时间复杂度和稳定性! 其实一直对稳定性不是很理解,今天研究python实现排序算法的时候突然有了新的体会,一定要记录下来 稳定性: 稳定性指的是 当排序碰到两个相等数的时候,他 ...
- python常见排序算法解析
python——常见排序算法解析 算法是程序员的灵魂. 下面的博文是我整理的感觉还不错的算法实现 原理的理解是最重要的,我会常回来看看,并坚持每天刷leetcode 本篇主要实现九(八)大排序算法 ...
- 第四百一十五节,python常用排序算法学习
第四百一十五节,python常用排序算法学习 常用排序 名称 复杂度 说明 备注 冒泡排序Bubble Sort O(N*N) 将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮 ...
- python 经典排序算法
python 经典排序算法 排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存.常见的内部排序算 ...
- JavaScript 排序算法——快速排序
常见排序 javaScript 实现的常见排序算法有:冒泡排序.选择排序.插入排序.谢尔排序.快速排序(递归).快速排序(堆栈).归并排序.堆排序. 过程 "快速排序"的思想很简单 ...
- Python经典排序算法
https://www.cnblogs.com/onepixel/p/7674659.html这个文章很nice https://www.bilibili.com/video/av685670?fro ...
- 数据结构和算法(Golang实现)(25)排序算法-快速排序
快速排序 快速排序是一种分治策略的排序算法,是由英国计算机科学家Tony Hoare发明的, 该算法被发布在1961年的Communications of the ACM 国际计算机学会月刊. 注:A ...
- 《Java算法》排序算法-快速排序
排序算法-快速排序: /** * 给定一个数组:按照从小到大排序. * 思路: * 1. 获取第一个数放入临时变量data,将大于data的数放右边,小于data的数放在左边. * 2. data左边 ...
随机推荐
- 常用 SQL Server 规范集锦
常用 SQL Server 规范集锦 常见的字段类型选择 1.字符类型建议采用varchar/nvarchar数据类型 2.金额货币建议采用money数据类型 3.科学计数建议采用numeric数 ...
- 数据分析与展示——Pandas数据特征分析
Pandas数据特征分析 数据的排序 将一组数据通过摘要(有损地提取数据特征的过程)的方式,可以获得基本统计(含排序).分布/累计统计.数据特征(相关性.周期性等).数据挖掘(形成知识). .sort ...
- Data Base mongodb driver2.5环境注意事项
mongodb driver2.5环境注意事项 一.问题: 如果使用vs2012开发就会报这个错误: 未能加载文件或程序集“System.Runtime.InteropServices.Runtime ...
- python学习日记:day11----装饰器进阶
1.wraps from functools import wraps def wrapper(func): #func = holiday @wraps(func)#输出holiday的函数名 de ...
- Thymeleaf引擎支持Multi Prefix
最近团队的一个项目在重构,希望引入Thymeleaf减少页面端的代码复杂性.在重构过程中,发现html文件需要保存在多个不同的目录中,但Thymeleaf缺省的实现不支持这种方式. 1 ...
- 转载|chrome developer tool—— 断点调试篇
断点,调试器的功能之一,可以让程序中断在需要的地方,从而方便其分析.也可以在一次调试中设置断点,下一次只需让程序自动运行到设置断点位置,便可在上次设置断点的位置中断下来,极大的方便了操作,同时节省了时 ...
- 限制ssh远程登陆
超过十次,就添加到hosts.deny里面去 #!/bin/bash date=`date +%Y%m%d` file="/var/log/secure" max=10 if [[ ...
- rabbitMQ教程(三) spring整合rabbitMQ代码实例
一.开启rabbitMQ服务,导入MQ jar包和gson jar包(MQ默认的是jackson,但是效率不如Gson,所以我们用gson) 二.发送端配置,在spring配置文件中配置 <?x ...
- RepeatMasker使用中的问题
RepeatMasker在运行时会先产生如下一个中间文件夹如RM_23346.WedAug301137422017,最后生成结果文件,例如.out,.masked,.tbl等 软件特性:软件运行很慢, ...
- php 简单通用的日志记录方法
使用file_put_contents 方法来实现简单便捷的日志记录功能 方法1: // use \r\n for new line on windows, just \n on linux func ...