求階乘代碼java 階乘 java
java用自定義輸入一個數(shù)求階乘怎么做
代碼如下
import java.util.Scanner;
public class Calculate {
public static void main(String[] args) {
// TODO Auto-generated method stub
long sum=1;
System.out.println("請輸入要計算階乘的正整數(shù):");
Scanner sc=new Scanner(System.in);
int b=sc.nextInt();
for (int i=1; i=b; i++) {
sum *=i;
}
System.out.println("該數(shù)的階乘為:"+sum);
}
}
java中怎么實現(xiàn)階乘,如計算1~100的階乘
使用BigInteger大容量運算類計算100的階乘
一.一般算法(循環(huán))
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);
}
}
輸出結(jié)果為0,因為int無法保存下100的階乘的結(jié)果,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);//調(diào)用自乘方法
}
System.out.println(result);//輸出結(jié)果
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);//調(diào)用自乘方法
}
System.out.println(result);//輸出結(jié)果
System.out.println(String.valueOf(result).length());//輸出長度
}
}
計算結(jié)果為:93326215443944152681699238856266700490715968264381621468592963895217599993229915608941463976156518286253697920827223758251185210916864000000000000000000000000
產(chǎn)度: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);
}
輸出的結(jié)果是2561327494111820313
擴展資料:
一個正整數(shù)的階乘(factorial)是所有小于及等于該數(shù)的正整數(shù)的積,并且0的階乘為1。自然數(shù)n的階乘寫作n!。1808年,基斯頓·卡曼引進(jìn)這個表示法。
亦即n!=1×2×3×...×n。階乘亦可以遞歸方式定義:0!=1,n!=(n-1)!×n。
計算方法:
大于等于1:
任何大于等于1 的自然數(shù)n 階乘表示方法:n! =?1×2×3×...×(n-1)n或n! = n×(n-1)!
0的階乘:0!=1。
參考資料:百度百科——階乘
Java 編寫一個方法,求一個數(shù)的階乘。 n!=1×2×3×...×n,比如3!=1*2*3=6?
方法和分析見下文:
分析
1、確定基本要求,應(yīng)作為方法的限定條件或特殊情況處理
(1)規(guī)定:0!=1
(2)規(guī)定:n!中n非負(fù)
2、確定邏輯:
階乘是比較適合遞歸的思路,因為n!=n*(n-1)!,直到求解1!作為結(jié)束
代碼(因為不太熟悉java,可能還需要題主進(jìn)行微調(diào))
long Factorials(int n)
{
if(n0) return -1;//主要為了表示錯誤,題主可以自定義
? if(n==1||n==0) return 1;//0!是特殊約定,1!是作為遞歸的結(jié)束
? else return n*Factorials(n-1);//進(jìn)行遞歸,求解階乘結(jié)果
}
欄 目:JavaScript
下一篇:java代碼的文件格式 java代碼的文件格式怎么寫
本文標(biāo)題:求階乘代碼java 階乘 java
本文地址:http://www.jygsgssxh.com/a1/JavaScript/17045.html
您可能感興趣的文章
- 04-02javascript點線,點線的代碼
- 04-02java吃豆人代碼 js吃豆人
- 04-02java中間代碼生成器 java自動生成代碼工具
- 04-02java代碼的文件格式 java代碼的文件格式怎么寫
- 04-02java代碼檢測工具 java代碼測試工具
- 04-02java菜單欄代碼 java菜單怎么寫
- 04-02微信挑一挑java代碼 微信挑一挑java代碼怎么做
- 04-02java反序數(shù)代碼 java list 反序
- 04-02java校驗組織機構(gòu)代碼 java校驗組織機構(gòu)代碼是什么
- 04-02網(wǎng)頁回復(fù)java代碼 javaweb評論回復(fù)功能


閱讀排行
本欄相關(guān)
- 04-02javascript點線,點線的代碼
- 04-02javascript潛力,javascript強大嗎
- 04-02javascript替換字符串,js字符串的替換
- 04-02javascript移出,js 移入移出
- 04-02包含javascript舍的詞條
- 04-02javascript并行,深入理解并行編程 豆瓣
- 04-02javascript匿名,js匿名方法
- 04-02javascript警報,JavaScript警告
- 04-02javascript遮蓋,JavaScript遮蓋PC端頁面
- 04-02javascript前身,javascript的前身
隨機閱讀
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-10delphi制作wav文件的方法
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 04-02jquery與jsp,用jquery
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實例總結(jié)


