递归算法的时间空间复杂度

空间复杂度

空间复杂度不是可执行文件的大小,是程序在运行时占用内存的大小。

int j = 0;
for(int i = 0; i < n; i++){
	j++;
}

以上程序段表示空间复杂度为O(1),在程序运行中消耗的内存空间一定,没有随着输入的变化而变化。

int *a = new int(n);
for(int i = 0; i < n; i++){
	a[i] = i;
}

以上程序在运行过程中随着n输入的增大,占用的内存空间也会增大。

斐波那契数列的递归时空分析

int fib(int i){
	if(i <= 0) return 0;
	if(i == 1) return 1;
	return fib(i-1) + fib(i-2);
}

递归算法的时间复杂度实际上是 每次递归的时间复杂度与递归次数相乘,在这段代码中每次递归都是O(1),但是递归的次数是一棵递归树,一颗深度为k的二叉树最多有 __2^k-1__个节点,因此该递归算法的时间复杂度为 O(2^n)
递归算法的空间复杂度实际上是 每次递归的空间复杂度与递归深度相乘,递归的深度为n,空间复杂度为 O(n)
对上述代码进行改进。

int fib(int first, int second, int i){
	if(i <= 0) return 0;
	if(i < 3)  return 1;
	else if(i == 3) return first + second;
	else {
		return fib(second, first+second, i-1);
	}
}

本次改进代码会记录当前两个相加的数值,每次递归的时间复杂度是O(1),递归的次数是i-1,因此该递归算法的时间复杂度为O(n)。
同样的空间复杂度为O(n)。

二分法的递归实现,时空分析

int binary_search(int arr[], int l, int r, int x){
	if(r >= 1){
		int mid = l + (r - l) / 2; //防止溢出
		if(arr[mid] == x) return mid;
		if(arr[mid] > x) return binary_serach(arr, l, r-1, x);
		return binary_serach(arr, l+1, r, x);
	}
	return -1;
}

我们知道二分法的时间复杂度是O(logn),空间复杂度是什么?
递归深度是logn,我们这时要注意,如果传递的参数是指数则空间复杂度为 O(logn),如果传递的是数组则每次复制还需要n的空间,空间复杂度为 O(nlogn)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值