原题链接:不容易系列
解题思路:
本人在写时,发现可以用递归来写。
什么是递归:(忙人请略过)
程序调用自身的编程技巧称为递归。递归做为一种算法在程序设计语言中广泛应用。递归,就是在运行的过程中调用自己。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。
下面是递归方程:
int f(int n) { if(n==1)return 1; return 2*f(n-1)+1; }
个人觉得代码算短的,递归一般思维复杂度不高,但时间复杂度就不好说了
注意事项:
递归要有终止条件:即n=1时返回1,在输出时,别忘了加3
参考代码:
#include<bits/stdc++.h> using namespace std; int f(int n) { if(n==1)return 1; return 2*f(n-1)+1; } int main() { int n; cin>>n; for(int i=1,x;i<=n;++i) { cin>>x; cout<<3+f(x)<<endl; } return 0; }
看到这里,点个赞再走吧!
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复