迭代和JDB
迭代和JDB
- 使用C(n,m)=C(n-1,m-1)+C(n-1,m)公式进行递归编程实现求组合数C(m,n)的功能。
- 源代码
public class Combination {
public static void main(String args[]) {
int c,n,m;
n = Integer.parseInt(args[0]);
m = Integer.parseInt(args[1]);
c = Result(n, m);
if (c == -1) System.out.println("Input error: m cannot be larger than n !");
else if (c == -2)System.out.println("Input error: m and n cannot be less than zero !");
else System.out.println(c);
}
public static int Result(int n, int m) {
if (m == 1) return n;
else if (m == 0 || m == n) return 1;
else if (n < m && n>0 && m>0) return -1;
else if (n < 0 || m < 0) return -2;
else
return Result(n - 1, m - 1) + Result(n - 1, m);
}
}
- 测试运行截图
- 正常情况
- 异常情况
- 边界情况
-
JDB调试
-
正常情况下用JDB调试程序c(X,2),X为学号最后一位+3
我学号5214,即取c(7,2)调试。
-
调试情况截图
-
即便不高谈理想,也要心存信仰。