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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 而今从头越2012 中级黑马   /  2012-12-28 13:34  /  2216 人查看  /  6 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

要求计算以下程序的结果:1! + 2! + 3! + …. + 35!,求出结果
方法一:通过普通的循环完成
public class MethodDemo09 {

  public static void main(String args[]){ double sum = 0.0 ;
  for(int x=1;x<35;x++){ double temp = 1 ; for(int y=1;y<=x;y++){
  temp *= y ;

  }
  sum += temp ;
  }
  System.out.println(sum) ;
  }
}
方法二:通过递归完成
public class MethodDemo10 {

  public static void main(String args[]){
   
  double sum = 0.0 ; for(int x=1;x<35;x++){
  sum += fun(x) ;

  }
  System.out.println(sum) ;
  }
  public static double fun(int temp){ if(temp==1){
  return 1 ;

  }else{
  return temp * fun(temp-1) ;
  }
  }
  };

评分

参与人数 1技术分 +1 收起 理由
奋斗的青春 + 1 很给力!

查看全部评分

6 个回复

正序浏览
王少雷 发表于 2012-12-28 17:38
飘过来飘过去,不错

涛哥,不要这么嘛 ~~~只是不知道应该发表点什么哈。
回复 使用道具 举报
递归方法借连续个阶乘相加问题不可取
回复 使用道具 举报
飘过来飘过去,不错

点评

闻名的酱油哥 。  发表于 2012-12-28 19:45
回复 使用道具 举报
飘过来飘过去,不错。·
回复 使用道具 举报
不同的方法用在不同的上面,毕竟任何一个方法都不是最全面的,这个只是用于大家的学习,开阔思维,举一反三。
回复 使用道具 举报
算法毋庸置疑,但是素我冒昧,小一点的数你的程序可以计算
但是如果我需要计算100加到1000的阶层和,你的程序就崩了{:soso_e122:}
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马