聊聊Python中的递归与快速排序那点事
最近买了两本算法相关的书,快速了翻看了一下,原来算法真是编程解决问题的最基础要素,以前很少关注算法这块,以为学了基础了解了一些框架包模块等就是学会了编程,请原谅我。。。
在Python中递归
递归比较简单的例子就是阶乘,看下递归的必要条件:
- 边界条件:确定递归到何时终止,也称为递归出口。
- 递归模式:大问题是如何分解为小问题的,也称为递归体。
阶乘中如果n=1那么就达到了边界条件,递归结束,如果大于1那么进入递归模式调用本体,具体看下代码:
def f(n):
if n == 1: return 1
return n * f(n - 1)
print(f(5))
上边就是一个简单的递归阶乘函数,很简单喽,不过在Python中,递归调用是有限制的,通过如下代码可以查看递归可以使用的层数:
import sys
sys.setrecursionlimit(5000) # 设置递归层数
print(sys.getrecursionlimit()) # 查看
Python中的快速排序
快速排序法是一个非常精典的递归例子,C语言标准库中的qsort函数的实现主是采用的快速排序法。
快速排序算法的边界条件是数组中只有一个成中了,即停止排序,否则继续递归模式。
具体看代码:
def q_sort(arr):
if len(arr) < 2 :
return arr
else:
p = arr[0]
print(p)
l = [i for i in arr[1:] if i <= p]
g = [i for i in arr[1:] if i > p]
temp = list()
temp.append(p)
return q_sort(l) + temp + q_sort(g)
print(q_sort([2,44,3,77,6,5,888,999]))
上边代码如果直接return q_sort(l) + p + q_sort(g)是会报错的,所以修改了使用list相加。
算法其实很有意思,程序都是有算法组成的,以后得多看看了。
本文源码下载:
标签: Python基础
相关文章
- 解决错误 ERROR [WinError 10049] 在其上下文中,该请求的地址无效。
- 如何在Python程序中使用配置文件.ini(ConfigParser)
- Python os.mknod 运行报错无法创建文件
- Python os.path.dirname(__file__) 在终端命令行下报错
- 妙用IPython学习Python--IPython快速上手
- Python生成器yield应用实例——监控日志
- 如何快速的复习学习过的Python
- python中导入不同目录中的自定义模块/class/函数/方法
- 浅谈Python中的协程及利用协程代替多线程及多进程并发编程
- 聊聊Python中晦涩的生成器(yield)与生成器表达式
- Python中创建TCP服务器与客户端进行通信(下)Tk、thread与socket组合。
- Python中创建TCP服务器与客户端进行通信(上)
- Python程序在Windows10终端运行中文乱码解决方法
- 你与黑客之间差了多少行Python代码?
- 聊聊Python闭包(Closure)的那点事。
- Python并发编程(下)功能强大设置简单的分布式多进程生产者与消费者模式
- Python并发编程(上)进程模块multiprocessing模块和Process类
- Python多线程编程(下)多线程锁 threading.Lock
- Python多线程编程(上)多线程创建的几种方法
- python 类的静态方法和类方法
- Python面向对象编程(OOP)初探
- Python random 随机数模块操作总结
- Python3 datetime模块的时间操作
- python3函数学习笔记简单总结
- PythonINI配置文件读写的简单方法
- Python open()函数文件打开、读、写操作总结
- Python os.path模块中一些常用方法的整理总结
- Python 采集数据三步曲之[Requests + re.py模块进行数据采集]
- Python 采集数据三步曲之[Requests开源协议的HTTP 库]
- Python 采集数据三步曲之[正则表达式 re.py]
- python3 Markdown模块解析Markdown代码
- 创建python 虚拟环境 venv