用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - java代码库

计算阶乘(非递归)

2012-11-15 作者: 神马举报

[java]代码库

public class Factorial {
	/**
	 * 计算n!的值
	 */
	public long getFactorial(int n) {
		// 因为当n大于17时,n!的值超过了long类型的范围,会出现错误。因此这里限定了n必须小于等于17。
		// 数学上没有负数的阶乘的概念,因此n必须大于等于0。
		if ((n < 0) || (n > 17)) {
			System.err.println("n的值范围必须在区间[0, 17]内!");
			return -1;
		} else if (n == 0) {
			// 0!的值为1
			return 1;
		} else {
			long result = 1;
			for (; n > 0; n--) {
				result *= n;
			}
			return result;
		}
	}
	public static void main(String[] args) {
		Factorial test = new Factorial();
		System.out.println(test.getFactorial(15));//1307674368000
	}
}


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...