最近开始学习王争老师的《数据结构与算法之美》,通过总结再加上自己的思考的形式记录这门课程,文章主要作为学习历程的记录。
分治算法的核心是分而治之,将原问题划分为n个规模较小,且结构与原问题相似的子问题,递归地解决了这些子问题,然后合并其结果,得到原问题的解。
分治算法一般都比较适合用递归来实现,每一层递归都会涉及这样三个操作:
1、分解:将原问题分解成一系列子问题。
2、解决:递归地求解各个子问题,若子问题足够小,则直接求解。
3、合并:将子问题的结果合并成原问题。
分治算法能解决的问题,一般需要满足下面几个条件:
1、原问题与分解成的小问题具有相同的模式。
2、原问题分解成的子问题可以独立求解,子问题之间没有相关性。
3、具有分解终止条件,即当问题足够小时,可以直接求解。
4、可以将子问题合并成原问题,合并操作复杂度不能过高。
分治算法应用举例分析
如何编程求出一组数据的逆序对个数?如果用分治思想来考虑,可以将数组分成前后两半A1和A2,分别计算A1和A2的逆序对个数K1和K2,然后再计算A1与A2之间的逆序对个数K3.那数组A的逆序对个数为K1+K2+K3。K3可以通过归并排序算法。
#归并排序求逆序数
def merge_sort(l1,l2):
l1 = sorted(l1)
l2 = sorted(l2)
l = []
num = 0
i,j = 0,0
while(i<len(l1) and j<len(l2)):
i