重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
楼主这个程序错的一塌糊涂
成都创新互联拥有十年成都网站建设工作经验,为各大企业提供成都网站建设、网站设计服务,对于网页设计、PC网站建设(电脑版网站建设)、成都App定制开发、wap网站建设(手机版网站建设)、程序开发、网站优化(SEO优化)、微网站、域名与空间等,凭借多年来在互联网的打拼,我们在互联网网站建设行业积累了很多网站制作、网站设计、网络营销经验,集策划、开发、设计、营销、管理等网站化运作于一体,具备承接各种规模类型的网站建设项目的能力。
都错在基础知识上。
稍等一下,我帮你改,再额外给你一个求阶乘的方法
import java.util.Scanner;
import java.math.BigInteger;
public class Outer {
public static void main(String[] args) {
int n;
//用do..while循环 当输入为0时,退出
do {
//从控制台获取一整数(包括20)
n = new Scanner(System.in).nextInt();
//把int转化成BigInteger类型
BigInteger result = BigInteger.valueOf(1);
//利用循环求出n!
for(int i = 2; i = n; i++) {
BigInteger b1 = BigInteger.valueOf(i);
result = result.multiply(b1);
}
System.out.println(result);
} while(n != 0);
}
}
方法二:用递归
import java.util.Scanner;
public class Test{
public static void main(String[] args) {
int input = new Scanner(System.in).nextInt();
int result = DiGui(input);
System.out.println(result);
}
//用递归求阶乘
public static int DiGui(int n) {
if(n == 1) {
return 1;
}
return n * DiGui(n - 1);
}
}
使用BigInteger大容量运算类计算100的阶乘
一.一般算法(循环)
view plaincopy to clipboardprint?
public class Test {
public static void main(String[] args) {
int result = 1;
for (int i = 1; i = 100; i++) {
result *= i;
}
System.out.println(result);
}
}
public class Test {
public static void main(String[] args) {
int result = 1;
for (int i = 1; i = 100; i++) {
result *= i;
}
System.out.println(result);
}
}
输出结果为0,因为int无法保存下100的阶乘的结果,100的阶乘的长度至少大于50位,也要大于long,double
二.使用BigInteger大容量运算类
view plaincopy to clipboardprint?
import java.math.BigInteger;
public class Test {
public static void main(String[] args) {
BigInteger result = new BigInteger("1");//为result赋初始值,为1
for (int i = 1; i = 100; i++) {
BigInteger num = new BigInteger(String.valueOf(i));
result = result.multiply(num);//调用自乘方法
}
System.out.println(result);//输出结果
System.out.println(String.valueOf(result).length());//输出长度
}
}
import java.math.BigInteger;
public class Test {
public static void main(String[] args) {
BigInteger result = new BigInteger("1");//为result赋初始值,为1
for (int i = 1; i = 100; i++) {
BigInteger num = new BigInteger(String.valueOf(i));
result = result.multiply(num);//调用自乘方法
}
System.out.println(result);//输出结果
System.out.println(String.valueOf(result).length());//输出长度
}
}
计算结果为:93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000
产度:158
亲测可用
long jiecheng(int x)
{
long int i,k=1;
for(i=1;i=x;i++)
k=k*i;
return k;
}
int main()
{
long int j,k=0;
int i;
for(i=1;i=20;i++)
{
j=jiecheng(i);
k+=j;
}
printf("%ld\n",k);
}
输出的结果是2561327494111820313
扩展资料:
一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。
亦即n!=1×2×3×...×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。
计算方法:
大于等于1:
任何大于等于1 的自然数n 阶乘表示方法:n! = 1×2×3×...×(n-1)n或n! = n×(n-1)!
0的阶乘:0!=1。
参考资料:百度百科——阶乘
//控制台数据自己获取.
int[] kim = new int[]{6,5,4,3,2,1}//这是应该从控制台获取
//递归方式获取阶乘
private int getJc(int k){
if(k=1){
return 1;
}else{
return k*getJc(k-1);
}
}
int result=0;
String buffer = "";
for(int i=0;ikim .length;i++){
if(i!=0){
buffer = buffer+" +"+kim[i]+"!";
}else{
buffer=buffer+kim[i] +"!";
}
result =result +kim[i];
}
buffer = buffer+"="+result;
System.out.println(buffer)
java中可以用for循环来实现阶层。
代码如下:
public class Demo {
public static void main(String[] args) {
for(int i=1;i5;i++){
int sum = 1;//定义一个用来存储阶层的值
for(int j=1;j=i;j++){//实现阶层的循环
sum *= j;
}
System.out.println(i+"的阶层是:"+sum);
}
}
}
for循环中的变量从1开始,循环遍历到阶层本身的这个数,通过一个变量来记录上一个数的乘积即可。
java程序计算20的阶乘,通过使用bigdecimal类来接收数据,如下例子:
public class Test{
public static void main(String[] args) {
BigDecimal cnt = new BigDecimal(0);
for (int i = 1; i = 20; i++) {
cnt = cnt.add(jiecheng(i));//循环计算20之内的阶乘
}
System.out.println(cnt);
}
public static BigDecimal jiecheng (int n) {
if (n == 1) {
return new BigDecimal(1);
}
//multiply()相乘
return jiecheng(n - 1).multiply(new BigDecimal(n));
}
}