数据结构——分治算法

最近开始学习王争老师的《数据结构与算法之美》,通过总结再加上自己的思考的形式记录这门课程,文章主要作为学习历程的记录。

分治算法的核心是分而治之,将原问题划分为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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值