递归和循环迭代
程序员文章站
2022-03-06 18:04:04
...
递归和迭代循环
编程题:有n步台阶,一次只能上1步或2步,共有多少种走法?
1. 递归
package test;
public class Test {
public int f(int n) {
// 实现f(n),求n步台阶一共有多少种走法
if(n < 1) {
// 抛出非法参数异常
throw new IllegalArgumentException(n+"不能小于1");
}
if(n==1 || n==2) {
return n;
}
return f(n-2) + f(n-1);
}
}
递归的时间是比较长的
2. 循环迭代
package test;
public class Test2 {
public int f(int n) {
// 实现f(n),求n步台阶一共有多少种走法
if(n < 1) {
throw new IllegalArgumentException(n+"不能小于1");
}
if(n==1 || n==2) {
return n;
}
int one = 2; // 初始化为走到第二级台阶的走法
int two = 1; // 初始化为走到第一级台阶的走法
int sum = 0;
for(int i=3;i<=n;i++) {
// 最后跨2步 + 最后跨1步的走法
sum = two + one;
two = one;
one = sum;
}
return sum;
}
}
3.小结
- 方法调用自身称为递归,利用变量的原值推出新值称为迭代。
- 递归
- 优点:大问题转换为小问题,可以减少代码量,同时代码精简,可读性好;
- 缺点:递归调用浪费了空间,而且递归太深容易造成堆栈的溢出。
- 迭代
- 优点:代码运行效率好,因为时间只因循环次数增加而增加,而且没有额外的空间开销;
- 缺点:代码不如递归简洁,可读性好
下一篇: php随机不重复查询mysql数据库