首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

分析递归函数的时间复杂度

递归算法的时间复杂度表达式: O(T) = R * O(s) O(T)表示时间复杂度 R表示递归调用的次数 O(s)每次递归调用计算的时间复杂度 想想斐波那契函数,它的递归关系是f(n)...解释:这种情况下,我们最好是可以借助执行树,它是一颗被用来表示递归函数执行流程的数。树中的每一个节点代表递归函数的一次调用。所以,树中节点的总数与执行期间递归调用的数量相对应。...所以,我们可以估算出f(n)的时间复杂度就是O(2n) 备忘录 备忘录技术是用来优化递归算法时间复杂度的技术。...通过缓存和重用中间结果的方式,备忘录可以极大地减少递归调用的次数,也就是减少执行树中分枝的数量。所以,当我们使用备忘录来分析递归算法的时间复杂度时候应该把这减少的部分考虑到。...现在我们就可以利用文章开头列出的公式来计算备忘录技术应用后的时间复杂度:O(1)n=O(n)。 结论 备忘录不仅优化算法的时间复杂度,而且还可以简化时间复杂度的计算。

71250

递归算法的时间复杂度

,第一层的遍历时间复杂度是n,第二层遍历的时间复杂度是n,内层的时间复杂度是O(n^2),再加上递归,最后的时间复杂度是O(2^n*n^2),这个算法可见很粗糙,假如递归深度到是100,最后执行效率简直会让人头皮发麻...第一层遍历时间复杂度是O(n),加上递归,最后的时间复杂度是O(2^n*n),不算太理想,最起码比第一次好点。 再看看一个面试的常见的题目,斐波拉契数列,n=1,1,3,5,8,13......(n-2) 这个算法的时间复杂度是O(2^n),关于时间复杂度具体看调用次数便能明白。...O(1),这样这个算法的时间复杂度就是O(n)。...递归算法的优化大概就是避免重复运算,将中金状态保存起来,以便下次使用,从结构上来看,是将时间复杂度转换为空间复杂度来解决。

2.2K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    递归算法的时间复杂度分析

    转自地址 http://blog.csdn.net/metasearch/article/details/4428865 在算法分析中,当一个算法中包含递归调用时,其时间复杂度的分析会转化为一个递归方程求解...这种递归方程是分治法的时间复杂性所满足的递归关系,即一个规模为n的问题被分成规模均为n/b的a个子问题,递归地求解这a个子 问题,然后通过对这a个子间题的解的综合,得到原问题的解。...一、代入法 大整数乘法计算时间的递归方程为:T(n) = 4T(n/2) + O(n),其中T(1) = O(1),我们猜测一个解T(n) = O(n2 ),根据符号O的定义,对n>n0,有...这里涉及的三类情况,都是拿f(n)与nlogb a 作比较,而递归方程解的渐近阶由这两个函数中的较大者决定。...在第一类情况下,函数nlogb a 较大,则T(n)=O(nlogb a );在第三类情况下,函数f(n)较大,则T(n)=O(f (n));在第二类情况下,两个函数一样大,则T(n)=O(nlogb

    1.9K50

    递归的时间复杂度(Master 公式)

    我们在解决算法问题时,经常会用到递归。递归在较难理解的同时,其算法的复杂度也不是很方便计算。而为了较为简便地评估递归的算法复杂度,Master公式。...Master公式含义T(N):表示当输入规模为 N 时,算法所需的时间复杂度。N 通常代表问题的规模,比如数据的数量、数组的长度、图的顶点数等。a:表示子问题的数量。...在分治算法中,a 常常代表每次递归调用产生的子问题数量。例如,在归并排序中,a 的值为 2,因为每次递归调用会将问题分为两个子问题。T(N/b):表示每个子问题的时间复杂度。...O(N^d):表示除了递归调用之外,算法在每次递归步骤中所做的额外工作的时间复杂度。O(N^d) 是除了递归调用之外的时间开销的上界。d 是一个常数,表示额外工作的时间复杂度与 N 的关系。...,这样子的话不符合相同规模的划分,就不能使用 Master 公式来计算时间复杂度​

    19210

    递归算法时间复杂度分析

    递归算法时间复杂度分析 时间复杂度: 一般情况下,算法中基本操作重复的次数就是问题规模n的某个函数f(n),进而分析f(n)随n的变化情况并确定T(n)的数量级。...这里用‘o’来表示数量级,给出算法时间复杂度。 T(n)=o(f(n)); 它表示随问题规模n的增大,算法的执行时间增长率和f(n)增长率成正比,这称作算法的渐进时间复杂度。...而我们一般情况下讨论的最坏的时间复杂度。 空间复杂度: 算法的空间复杂度并不是实际占用的空间,而是计算整个算法空间辅助空间单元的个数,与问题的规模没有关系。...经验和一些定理告诉我们,这些细节不会影响算法时间复杂度的渐近界。   类似的,我们也可以用迭代法求解汉诺塔递归求解时的时间复杂度。但遗憾的是,迭代法一般适用于一阶的递推方程。...这个递推式将规模为n的问题分解为a个子问题,每个子问题的规模为n/bn/b,a个子问题递归地求解,每个花费时间T(n/b)T(n/b)。函数f(n)f(n)包含了问题分解和子问题解合并的代价。

    2.6K20

    剖析递归行为和递归行为时间复杂度的估算

    一个递归行为的例子 master公式的使用 T(N) = a*T(N/b) + O(N^d) T(N)是样本量为N时的时间复杂度,N/b是划分成子问题的样本量,子问题发生了a次,后面O(N^d)是除去调用子过程之外的时间复杂度...(arr, mid + 1, R);         return Math.max(maxLeft, maxRight);     } T(N) = 2*T(N/2) + O(1); 这里划分成的递归子过程的样本量是...N/2,这个相同的样本量发生了2次,除去调用子过程之外的时间复杂度是O(1),因为求最大值和判断if复杂度是O(1),所以N^d=1,所以d=0....那么根据如下公式判断 1) log(b,a) > d -> 复杂度为O(N^log(b,a)) 2) log(b,a) = d -> 复杂度为O(N^d * logN) 3) log(b,a) 复杂度为O(N^d) 这里log(b, a)(以b为底a的对数) = log(2, 2)=1 > d=0 所以复杂度为O(N^log(2, 2))===>O(N),因此也就可以解释为什么归并排序的时间复杂度为

    19310

    剖析递归行为和递归行为时间复杂度的估算

    剖析递归行为和递归行为时间复杂度的估算 master公式:也叫主定理。它提供了一种通过渐近符号表示递推关系式的方法。 应用Master定理可以很简便的求解递归方程。...master公式的使用 递归行为形如: T(N) = a*T(N/b) + O(N^d) 均可用下面推到出时间复杂度 (1) log(b,a) > d -> 复杂度为O(N^log(b,a)) (2)...log(b,a) = d -> 复杂度为O(N^d * logN) (3) log(b,a) 复杂度为O(N^d) T(N):       递归的时间复杂度 N:            ...递归行为的规模|样本数量 N/b:         递归后子过程的规模 (b指的是子过程分为几块,比如递归比较运算是左右两块) a:               子过程调用次数 aT(N/b...):    所有子过程的时间复杂度 O(N^d) :    除去子过程之外剩下过程的时间复杂度 注意: 1.使用master公式推到时间复杂度必须保证每次划分的子工程的规模是一样的 如果形如:

    50430

    递归树:借助树来求解递归算法时间复杂度

    利用递归树的时间复杂度分析方法并不难理解,关键还是在实战,所以,接下来我会通过三个实际的递归算法,带你实战一下递归的复杂度分析。学完这节课之后,你应该能真正掌握递归代码的复杂度分析。...,这个递归代码的时间复杂度会比较难分析。...这里我稍微说下,掌握分析的方法很重要,思路是重点,不要纠结于精确的时间复杂度到底是多少。 内容小结 今天,我们用递归树分析了递归代码的时间复杂度。...加上我们在排序那一节讲到的递推公式的时间复杂度分析方法,我们现在已经学习了两种递归代码的时间复杂度分析方法了。...有些代码比较适合用递推公式来分析,比如归并排序的时间复杂度、快速排序的最好情况时间复杂度;有些比较适合采用递归树来分析,比如快速排序的平均时间复杂度。

    1.5K10

    一场面试,带你彻底掌握递归算法的时间复杂度

    很多同学对递归算法的时间复杂度都不甚了解 同一道题目,同样使用递归算法,有的同学写出了O(n)的代码,有的同学就写出了O(logn)的代码 这是为什么呢, 就是因为对递归的时间复杂度理解的不够深入导致的...如果恰巧正在读本文的你也对递归算法的时间复杂度懵懵懂懂,请认真读完本篇文章,一定会有所收获 这里我想通过一道简单的面试题,来带大家逐步分析递归算法的时间复杂度,最后找出最优解。...每次n-1,递归了n次 时间复杂度是O(n),每次进行了一个乘法操作,乘法操作的时间复杂度一个常数项O(1) 所以这份代码的时间复杂度是 n * 1 = O(n) 这个时间复杂度可能就没有达到面试官的预期...这个结论在二叉树相关的面试题里也经常出现。 这么如果是求x的n次方,这个递归树有多少个节点呢,如下图所示 ? 时间复杂度忽略掉常数项-1之后,我们发现这个递归算法的时间复杂度依然是O(n)。...如果同学们最后写出了这样的代码并且时间复杂度分析的非常清晰,相信面试官是比较满意的。 最后希望通过这么一个简单的面试题,让大家真正了解了递归算法的时间复杂度该如何分析。

    67710

    函数的递归

    1.递归思想: 把一个复杂的问题拆分成一个一个小的问题,直到小的问题不能再被拆分。 递是传递的意思,归是回归的意思,下文举例说明。 1条件: (1)递归存在条件,当不满足这个条件时就停止递归 。...的阶乘就是n*(n-1)*(n-2)*........*1,这是一道数学问题,要把他转化为编程逻辑,一般 先想到的是循环,从1一开始一直乘到n结束,使用递归也同样简单,如图 利用这种方法完成递归,首先创建一个子函数...} 要想完成1234的分离,首先把4分离出来,其次在分离3,一直分离到1,传递参数进入子函数,1234>9,在进入123,,123也大于9,进入12,还是大于9,在进入1,1递归结束,首先完成1的打印...利用图来解释更为直观一些,函数递归一直执行到限制条件为止,正如开头所说,执行到1为止,依次回归,打印各位数字 最后完成程序 #include void Print(long n) {...,却能执行复杂的计算,一定程度上为程序员节省了时间,但是递归有时也有缺点,计算过程复杂导致计算慢,更多的需要程序员去探索

    5710

    算法的时间复杂度

    算法的效率: 是指算法执行的时间,算法执行时间需要通过算法编制的程序在计算机上运行时所消耗的时间来衡量。 一个算法的优劣可以用空间复杂度和时间复杂度来衡量。 时间复杂度:评估执行程序所需的时间。...算法设计时,时间复杂要比空间复杂度更容易复杂,所以本博文也在标题指明讨论的是时间复杂度。一般情况下,没有特殊说明,复杂度就是指时间复杂度。...(上面提到了) 一般情况下,算法中基本操作重复执行的次数是问题规模n的某个函数,用T(n)表示,若有某个辅助函数f(n),使得当n趋近无穷大时,T(n)/f(n)的极限值为不等于零的常数,则称为f(n)...是T(n)的同数量级函数。...T(n) = O(f(n))称函数T(n)以f(n)为界或称T(n)受限于f(n)。如果一个问题的规模是n,解决一问题的某一算法所需要的时间为T(n)。

    1.2K20

    函数的递归

    递归是什么? 递归是学习C语⾔函数绕不开的⼀个话题,那什么是递归呢? 递归其实是⼀种解决问题的方法,在C语⾔中,递归就是函数⾃⼰调⽤⾃⼰。 ...在C语⾔中每⼀次函数调⽤,都需要为本次函数调⽤在内存的栈区,申请⼀块内存空间来保存函数调 ⽤期间的各种局部变量的值,这块空间被称为运⾏时堆栈,或者函数栈帧。...函数不返回,函数对应的栈帧空间就⼀直占⽤,所以如果函数调⽤中存在递归调⽤的话,每⼀次递归 函数调⽤都会开辟属于⾃⼰的栈帧空间,直到函数递归不再继续,开始回归,才逐层释放栈帧空间。...举例3:求第n个斐波那契数  我们也能举出更加极端的例⼦,就像计算第n个斐波那契数,是不适合使⽤递归求解的,但是斐波那契 数的问题通过是使⽤递归的形式描述的,如下: 当我们n输⼊为50的时候,需要很⻓时间才能算出结果...,这个计算所花费的时间,是我们很难接受的, 这也说明递归的写法是⾮常低效的,那是为什么呢?

    5110

    Python中变量的含义和作用

    变量可以说是任意一个编程语言都存在的一个定义,变量是必学。变量分为三个方面来讲解,分别是变量的作用,定义变量、认识数据类型。三个方面也就是三篇文章,大家可以持续关注来进一步学习Python变量。...变量的含义: 程序中,数据都是临时存储在内存中的,为了更快速的查找或使用这个数据,通常我们把这个数据在内存中存储之后定义一个名称,这个名称就是变量。...举例来说明变量含义: 比如我们去图书馆看书,那么怎么样快速的找到我们想要的书呢?...我们存储数据的时候相当于在图书馆里去找一本书,想要快速的找到这个数据,就可以看看下面的内存图,一个变量名对应一个内存位置,一个内存位置对应一个数据。...变量的作用: 变量就是存储数据的时候把当前数据所在的内存地址起的名字。

    99610

    时间复杂度的计算

    时间复杂度 方法: 1、按效率从高到低排列: 2、取最耗时的部分 4个便利的法则: 对于一个循环,假设循环体的时间复杂度为 O(n),循环次数为 m,则这个循环的时间复杂度为 O(n×...\n"); // 循环体时间复杂度为 O(1) }} 时间复杂度为:O(n×1) 对于多个循环,假设循环体的时间复杂度为 O(n),各个循环的循环次数分别是a, b, c…...,则这个循环的时间复杂度为 O(n×a×b×c…)。...\n"); // 循环体时间复杂度为 O(1) } }} 时间复杂度为:O(1×n×n),即O(n²) 对于顺序执行的语句或者算法,总的时间复杂度等于其中最大的时间复杂度...\n"); } } 时间复杂度为:O(n²) 对于条件判断语句,总的时间复杂度等于其中时间复杂度最大的路径 的时间复杂度。

    84930
    领券