黑马程序员技术交流社区

标题: 运行结果 [打印本页]

作者: wangjie084    时间: 2016-6-10 23:23
标题: 运行结果
public class Test {
        public static void main(String[] args) throws IOException {
                System.out.println(fun(5));
        }
        public static int fun(int num) {
                if(num == 1) {
                        return 1;
                }else {
                        return num * fun(num - 1);
                }
        }
}
哪位大神说说咋解答啊?一个个算到底就没啦啊


作者: 流离岁月    时间: 2016-6-10 23:38
你写的是递归吧,应该是120,但不应该抛出Io异常
作者: ancheng    时间: 2016-6-11 19:54
  1. 这是一个利用递归算法计算5的阶乘的吧!但是真的有必要抛IOException?
复制代码

作者: jianhua0798    时间: 2016-6-11 22:45
  1. 不用抛异常啊,源码这样写就行,不用else
  2. public class Demo {
  3.         public static void main(String[] args) {
  4.                 System.out.println(jieCheng(5));
  5.         }
  6.         //求某数的阶乘
  7.         public static int jieCheng(int num){//num = 5
  8.                 if(num == 1){
  9.                         return 1;
  10.                 }
  11.                 return num * jieCheng(num - 1);
  12.         }
  13.        
  14. }
复制代码



作者: 见著    时间: 2016-6-11 23:01
不用抛出异常啊
作者: wangjie084    时间: 2016-6-11 23:04
流离岁月 发表于 2016-6-10 23:38
你写的是递归吧,应该是120,但不应该抛出Io异常

哦哦,那我写的不对可能
作者: wangjie084    时间: 2016-6-11 23:06
流离岁月 发表于 2016-6-10 23:38
你写的是递归吧,应该是120,但不应该抛出Io异常

哦哦,那我写的不对可能
作者: 善良的死神达乐    时间: 2016-6-11 23:33
问题升级一下,求1000的阶乘...
提示...因为是1000的阶乘,超出int的取值范围,long都超过,所以用bigInteger接收,再把它转换成String类型的字符串,这样就可以打印啦...
作者: ancheng    时间: 2016-6-11 23:52
善良的死神达乐 发表于 2016-6-11 23:33
问题升级一下,求1000的阶乘...
提示...因为是1000的阶乘,超出int的取值范围,long都超过,所以用bigInteger接 ...

1000的阶乘用递归做不会出问题吗?
作者: 善良的死神达乐    时间: 2016-6-12 20:41
ancheng 发表于 2016-6-11 23:52
1000的阶乘用递归做不会出问题吗?

不会....要到7000估计会栈内存溢出.......




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2