算法思想 -- 分治算法

分治法介绍


  在计算机科学中,分治法是建基于多项分支递归的一种很重要的算法范式。字面上的解释是“分而治之”,就是把一个复杂的问题分成两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并。(参考 :wiki分治法) 

分治法 & 数学


分治法本质上是数学归纳法,所以分治法的算法的正确性可以通过数学归纳法证明的方式来证明。

(PS: 动态规划也是数学归纳)

分治法正确性证明

算法的正确性证明方法一: 循环不变量
算法的正确性证明方法二: 结构归纳法

分治法关键步骤

循环递归


在每一层递归上都有三个步骤:
分解:将原问题分解为若干个规模较小,相对独立,与原问题形式相同的子问题。
解决:若子问题规模较小且易于解决时,则直接解。否则,递归地解决各子问题。
合并:将各子问题的解合并为原问题的解。
PS:
一般而言,合并(combine)是最难的部分。

划分方式举例

  不同的划分方式,将会导致计算的复杂度,思考的难度,所以简洁,高效的划分方式十分有用。

总结

   【前n个为一个单位,只限制结尾】leetcode – 53. Maximum Subarray
   【i到j为一个单位,限制头尾】归并排序
  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值