迭代和JDB
Posted 1751-pyc
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了迭代和JDB相关的知识,希望对你有一定的参考价值。
要求
1 使用C(n,m)=C(n-1,m-1)+C(n-1,m)公式进行递归编程实现求组合数C(m,n)的功能 2 m,n 要通过命令行传入 3 提交测试运行截图(至少三张:正常如c(3,2)、异常如c(2, 3)、边界情况如c(m,m)) 4 提交正常情况下用JDB调试程序c(X,2)的截图,X为学号最后一位+3,至少四张截图 5 把代码推送到码云
1.代码
import java.util.Scanner; public class Test{ public static void main(String args[]){ Digui_zuheshu zhs=new Digui_zuheshu(); Scanner s=new Scanner(System.in); int a=s.nextInt(); int b=s.nextInt(); System.out.println(zhs.C(a,b)); } }
class Digui_zuheshu { int C(int n,int m){ if(m==0||m==n) return 1; if(m==1) return n; if(n<=0||n<m) return -1; else return C(n-1,m-1)+C(n-1,m); } }
2.代码测试
正常:
异常:
边界:
3.JDB调试
由于java -g 编译不通过,无法查看本地变量,设置m,n的值
代码编写调试过程中的问题:
1.在递归算法的编写中,在else的情况里我总是得不到正确的输出
解决:将方法C(int m,int n)中的m,n交换
2.main方法中创建对象时,实际参数列表与形式参数列表长度不同。
解决:实际参数有两个,但定义的输入只有一个。所以要用Scanner创建对象,用nextInt生成两个参数。
以上是关于迭代和JDB的主要内容,如果未能解决你的问题,请参考以下文章