我们专注攀枝花网站设计 攀枝花网站制作 攀枝花网站建设
成都网站建设公司服务热线:400-028-6601

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

阶乘相乘的java代码 java中的阶乘

Java阶乘 程序

楼主这个程序错的一塌糊涂

成都创新互联拥有十年成都网站建设工作经验,为各大企业提供成都网站建设、网站设计服务,对于网页设计、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);

}

}

java中怎么实现阶乘,如计算1~100的阶乘

使用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

java怎么写求阶乘?

亲测可用

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。

参考资料:百度百科——阶乘

java 阶乘的代码

//控制台数据自己获取.

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中怎么表示阶乘

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的阶乘?

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));

}

}


本文题目:阶乘相乘的java代码 java中的阶乘
文章来源:http://mswzjz.cn/article/dochssh.html

其他资讯