您的位置:首页 > 其它

上台阶

2015-09-03 13:56 225 查看
斐波那契数列变种

public class ThreeStair {
/**
* 一个小孩上一个N级台阶的楼梯,他可以一次走1阶、2阶或3阶,那么走完N阶有多少种方式。
* */
public static int waysToMoveUp(int n) {
if (n < 0)
return -1;
if (n < 3) {
if(n == 0) {
return 1;
}
return n;
}
int[] ways = new int[n + 1];
ways[0] = 1;
ways[1] = 1;
ways[2] = 2;
for(int i=3; i<=n; ++i) {
ways[i] = ways[i-1] + ways[i-2] + ways[i-3];
}
return ways
;
}

public static void main(String[] args) {
System.out.println(ThreeStair.waysToMoveUp(5));
}
}

可以用三个变量存钱三个数。

public class ThreeStair {
/**
* 一个小孩上一个N级台阶的楼梯,他可以一次走1阶、2阶或3阶,那么走完N阶有多少种方式。
* */
public static int waysToMoveUp(int n) {
if (n < 0)
return -1;
if (n < 3) {
if(n == 0) {
return 1;
}
return n;
}
int a = 1;
int b = 1;
int c = 2;
for(int i=3; i<=n; ++i) {
int t = a + b + c;
a = b;
b = c;
c = t;
}
return c;
}

public static void main(String[] args) {
System.out.println(ThreeStair.waysToMoveUp(5));
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: