A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© wangjie084 中级黑马   /  2016-6-10 23:23  /  633 人查看  /  9 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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);
                }
        }
}
哪位大神说说咋解答啊?一个个算到底就没啦啊

9 个回复

倒序浏览
你写的是递归吧,应该是120,但不应该抛出Io异常
回复 使用道具 举报
  1. 这是一个利用递归算法计算5的阶乘的吧!但是真的有必要抛IOException?
复制代码
回复 使用道具 举报
  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-10 23:38
你写的是递归吧,应该是120,但不应该抛出Io异常

哦哦,那我写的不对可能
回复 使用道具 举报
流离岁月 发表于 2016-6-10 23:38
你写的是递归吧,应该是120,但不应该抛出Io异常

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

1000的阶乘用递归做不会出问题吗?
回复 使用道具 举报
ancheng 发表于 2016-6-11 23:52
1000的阶乘用递归做不会出问题吗?

不会....要到7000估计会栈内存溢出.......
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马