在前面的排序算法学习中,归并排序和快速排序就是用的分治法,分治法作为三大算法之一的,有非常多的应用例子。

分治法概念

将一个复杂的问题分成两个或更多的相同或相似的子问题,再把子问题分成更小的子问题----“分”

将最后子问题可以简单的直接求解----“治”

将所有子问题的解合并起来就是原问题打得解----“合”

分治法特征

该问题的规模缩小到一定的程度就可以容易地解决

该问题可以分解为若干个规模较小的相同问题,即该问题具有最优子结构性质。

利用该问题分解出的子问题的解可以合并为该问题的解;

该问题所分解出的各个子问题是相互独立的,即子问题之间不包含公共的子子问题。

第一条特征是绝大多数问题都可以满足的,因为问题的计算复杂性一般是随着问题规模的增加而增加;

第二条特征是应用分治法的前提它也是大多数问题可以满足的,此特征反映了递归思想的应用;、

第三条特征是关键,能否利用分治法完全取决于问题是否具有第三条特征,如果具备了第一条和第二条特征,而不具备第三条特征,则可以考虑用贪心法或动态规划法。

第四条特征涉及到分治法的效率,如果各子问题是不独立的则分治法要做许多不必要的工作,重复地解公共的子问题,此时虽然可用分治法,但一般用动态规划法较好。

分治法例子:

一、对数组进行快速排序

'''

时间复杂度O(nlogn)

pivot枢纽,low和high为起点终点

'''

#划分分区(非就地划分)

def partition(nums=list):

pivot= nums[0] #挑选枢纽

lo = [x for x in nums[1:] if x < pivot] #所有小于pivot的元素

hi = [x for x in nums[1:] if x >= pivot] #所有大于pivot的元素

returnlo,pivot,hi#快速排序

def quick_sort(nums=list):#被分解的Nums小于1则解决了

if len(nums) <= 1:returnnums#分解

lo,pivot,hi =partition(nums)#递归(树),分治,合并

return quick_sort(lo) + [pivot] +quick_sort(hi)

lis= [7, 5, 0, 6, 3, 4, 1, 9, 8, 2]print(quick_sort(lis)) #[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

二、对数组进行归并排序

'''名字很多:归并排序/合并排序/二分排序

时间复杂度 O(logn)

递归

两个步骤:1.拆分 2.合并'''

def merge_sort(nums=list):#取mid以及左右两个数组

mid = len(nums)//2left_nums,right_nums=nums[:mid],nums[mid:]#递归分治

if len(left_nums) > 1:

left_nums=merge_sort(left_nums)if len(right_nums) > 1:

right_nums=merge_sort(right_nums)#合并

res =[]while left_nums and right_nums: #两个都不为空的时候

if left_nums[-1] >= right_nums[-1]: #尾部较大者

res.append(left_nums.pop())else:

res.append(right_nums.pop())

res.reverse()#倒序

return (left_nums or right_nums) + res #前面加上剩下的非空nums

lis= [7, 5, 0, 6, 3, 4, 1, 9, 8, 2]print(merge_sort(lis)) #[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

三、给定一个顺序表,编写一个求出其最大值的分治算法

#O(nlogn)

#基本子算法(内置算法)#虽然也可以处理大数组,这里用于解决分治问题规模小于2时候

def get_max(nums=list):returnmax(nums)#分治法

defsolve(nums):

n=len(nums)if n <= 2: #分治问题规模小于2时解决

returnget_max(nums)#分解(子问题规模为 n/2)

left_list, right_list = nums[:n//2], nums[n//2:]#递归(树),分治

left_max, right_max =solve(left_list), solve(right_list)#合并

returnget_max([left_max, right_max])if __name__ == "__main__":#测试数据

alist = [12,2,23,45,67,3,2,4,45,63,24,23]#求最大值

print(solve(alist)) #67

四、给定一个顺序表,判断某个元素是否在其中

#O(nlogn)#子问题算法(子问题规模为1)

defis_in_list(nums,key):if nums[0] ==key:print('Yes! %d in the nums' %key)else:print('Not found')#分治法

defsolve(nums,key):

n=len(nums)#N==1时解决问题

if n == 1:returnis_in_list(nums,key)#分解

left_list,right_list = nums[:n//2],nums[n//2:]#递归(树),分治,合并

res = solve(left_list,key) orsolve(right_list,key)returnresif __name__ == '__main__':#测试

lis = [12,2,23,45,67,3,2,4,45,63,24,23]#查找

print(solve(lis,45)) #YES~

print(solve(lis,5)) #NOT~

五、找出一组序列中的第 k 小的元素,要求线性时间

'''O(nlogn)

用快排的方法,选定pivot然后通过左右两个分组递归得出结果'''

#划分

def partition(nums=list):

pi=nums[0]

lo= [x for x in nums[1:] if x

hi= [x for x in nums[1:] if x >=pi]returnlo,pi,hi#查找第 k 小的元素

defsolve(nums,key):#分解

lo,pi,hi =partition(nums)

n=len(lo)#解决

if n ==key:returnpi#递归分治

elif n

else:returnsolve(lo,key)if __name__ == '__main__':

lis= [3, 4, 1, 6, 3, 7, 9, 13, 93, 0, 100, 1, 2, 2, 3, 3, 2]print(solve(lis,3))#2

print(solve(lis,10))#4

python分治算法_分治法及其python实现例子相关推荐

  1. python分治算法_黄哥Python:分治算法(Divide-and-Conquer)

    分治算法(Divide-and-Conquer) 在计算机科学中,分而治之(简称分治法)是基于多分支递归的算法设计范例.分而治之算法的工作原理是将问题递归分解为两个或多个相同或相关类型的子问题,直到这 ...

  2. python分治算法_算法-分治

    分治算法的基本思想是将一个规模为N的问题分解为K个规模较小的子问题,这些子问题相互独立且与原问题性质相同.求出子问题的解,就可得到原问题的解,是一种分目标完成程序算法,简单的问题可用二分法完成. 1. ...

  3. python五大算法_一文洞悉Python必备50种算法!资深大牛至少得掌握25种!

    一.环境需求 二.怎样使用 三.本地化 3.1扩展卡尔曼滤波本地化 3.2无损卡尔曼滤波本地化 3.3粒子滤波本地化 3.4直方图滤波本地化 四.映射 4.1高斯网格映射 4.2光线投射网格映射 4. ...

  4. python价值算法_第十课-Python金融学基础——夏普比率(Sharpe-ratio)和资产组合价值(portfolio-value)...

    前面的课程主要是在研究Pandas的时序分析实现,以及利用statsmodel对时序数据进行ARIMA以及有权重的ARIMA模型的建模,并尝试预测未来的走向.从这节课开始,我们正式进入Python金融 ...

  5. 趣学算法系列-分治法

    趣学算法系列-分治法 声明:本系列为趣学算法一书学习总结内容,在此推荐大家看这本算法书籍作为算法入门, 原作者博客链接,本书暂无免费电子版资源,请大家支持正版,更多实例分析请查看原书内容 第三章 分治 ...

  6. python编程基础_月隐学python第2课

    python编程基础_月隐学python第2课 学习目标 掌握变量的输入和输出 掌握数据类型的基本概念 掌握算数运算 1.变量的输入和输出 1.1 变量输入 使用input输入 input用于输入数据 ...

  7. 查看Python的版本_查看当前安装Python的版本

    一.查看Python的版本_查看当前安装Python的版本 具体方法: 首先按[win+r]组合键打开运行: 然后输入cmd,点击[确定]: 最后执行[python --version]命令即可. 特 ...

  8. python矩阵乘法分治算法_矩阵乘法的Strassen算法详解 --(算法导论分治法求矩阵)...

    1 题目描述 2 思路分析 3 解法 4 小结 1 题目描述 请编程实现矩阵乘法,并考虑当矩阵规模较大时的优化方法. 2 思路分析 根据wikipedia上的介绍:两个矩阵的乘法仅当第一个矩阵B的列数 ...

  9. python分治算法_Python算法:分治法

    本节主要介绍分治法策略,提到了树形问题的平衡性以及基于分治策略的排序算法 本节的标题写全了就是:divide the problem instance, solve subproblems recur ...

最新文章

  1. 操作像素(一)--存取像素值
  2. python编程if语法-二、python 语法之变量赋值与if(if else)
  3. [YTU]_2635(P4 游戏中的Human角色)
  4. 用squid配置代理服务器(基于Ubuntu Server 12.04)
  5. JDK 8 新特性 之 方法引用
  6. ubuntu下如何查找某个文件的路径
  7. (第2篇)一篇文章教你轻松安装hadoop
  8. 我那么拼命,为什么还会被裁掉?
  9. HttpWebRequest自动登录网站并获取网站内容(不包含验证码的网站)
  10. oracle timestamp计算两分钟前_阿里数据库真的超过Oracle了么?
  11. OpenQA.Selenium.WebDriverException : Failed to start up socket within 45000
  12. 如何优雅的输出PHP调试信息
  13. 获取GridView的BoundField值
  14. 智能优化算法:花授粉算法-附代码
  15. 华为官方解锁工具_渣男为何爱用华为手机?
  16. 搜狗站长工具:索引量与收录量的解释,它等同于site的收录吗?
  17. iOS微信消息延迟和不提醒,这样即可解决
  18. html文字溢出用省列号,关于文字内容溢出用点点点(...)省略号表示
  19. html里如何定位背景图片,Html+Css CSS中背景图片定位方法
  20. 云计算机渲染效果,什么是云渲染?云渲染这么用?

热门文章

  1. Nginx 502 Bad Gateway 错误的原因及解决方法
  2. MPLS-L3×××中的公网访问
  3. Java并发编程之synchronized关键字解析
  4. Project查看资源分配情况
  5. 1.android体系结构介绍
  6. linux查看当前用户终端,Linux----基本命令的使用(vi命令,查看文件内容,显示进程,切换用户等)...
  7. sql count为空时显示0_C0010负坐标显示为正数+红色0值参考线
  8. python 神经网络工具_神经网络15分钟入门!使用python从零开始写一个两层神经网络...
  9. cd-rom门锁定什么意思_CD-ROM XA的完整格式是什么?
  10. nginx服务器配置安全维护,Nginx服务器相关的一些安全配置建议