码迷,mamicode.com
首页 > 其他好文 > 详细

hdu-2045 递归

时间:2015-07-10 15:13:53      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:递归

#include <cstdio>
#include <iostream>
using namespace std;
long long a[55] = {0,3,6};
long long b[55] = {0,0,0,6};
long long int fun(int x);
long long int funa(int x);

long long int fun(int x){
	if(a[x]) return a[x];
	return a[x] = funa(x-1) * 2 + fun(x-1); 
}

 
long long int funa(int x){
	if(b[x]) return b[x];
	if(x <= 2) return 0;
	
	return b[x] = fun(x-1);
}
int main(){
	
	int n;
	fun(50);
	while(cin >> n){
		printf("%I64d\n",a[n]);
	}
	return 0;
	
}

这道题虽然看起来很简单,但是确实用到了两路同时进行的递归的方法!觉得很新颖,这种两种递归的方法给了我很好的其实,一个递归问题可以用另一个依赖递归的问题求解。

版权声明:本文为博主原创文章,未经博主允许不得转载。

hdu-2045 递归

标签:递归

原文地址:http://blog.csdn.net/qq_24667639/article/details/46830289

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!