学习笔记:主定理

本文探讨了如何使用主定理来确定递归式和常见算法的复杂度。介绍了代换猜测法、递归树法、直接数学分析法以及主定理作为常用方法,特别强调了主定理在处理分治法得到的递推关系式中的作用。通过实例展示了如何处理不符合主定理标准的递归情况,并提及了基于递归的快速排序、归并排序和二分查找等算法的复杂度分析。
摘要由CSDN通过智能技术生成
众所周知,递归是算法的一个重要表现形式,不仅作用大,而且其复杂度的分析也比其他方式要繁杂。

但是,如果抛开某些很NB,很强大,很邪恶的递归式不谈,如果不能有效的确定普通递归式和一些典型算法递归式的复杂度,那么这个人显然不是合格的Coder。

由于递归式复杂度的难以确定,所以目前常用的方法有这么几种:代换猜测法、递归树法、主定理、直接数学分析法

代换猜测法通常和递归树法合用,利用递归树法得到一个大概正确的结果,然后利用数学归纳法对其验证。

直接的数学分析法相对很直接,很强悍,但是对数学要求很高,尤其是碰到一些BT的表达式

其中,主定理是最常用的方法。

在算法分析中,主定理(master theorem)提供了用渐近符号表示许多由分治法得到的递推关系式的方法。

主定理通常可以解决如下的递归表达式:

T(n)=a*T(n/b)+f(n)

上面的递归式描述的是将规模为n的问题划分为a个子问题,并且每个子问题的规模是n/b,这里a和b是正常数。划分原问题和合并结果的代价有函数f(n)描述。

主定理有三种情况,不同的情况有不同的用法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值