求階乘代碼java 階乘 java
java用自定義輸入一個(gè)數(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("請輸入要計(jì)算階乘的正整數(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中怎么實(shí)現(xiàn)階乘,如計(jì)算1~100的階乘
使用BigInteger大容量運(yùn)算類計(jì)算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,因?yàn)閕nt無法保存下100的階乘的結(jié)果,100的階乘的長度至少大于50位,也要大于long,double
二.使用BigInteger大容量運(yùn)算類
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());//輸出長度
}
}
計(jì)算結(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
擴(kuò)展資料:
一個(gè)正整數(shù)的階乘(factorial)是所有小于及等于該數(shù)的正整數(shù)的積,并且0的階乘為1。自然數(shù)n的階乘寫作n!。1808年,基斯頓·卡曼引進(jìn)這個(gè)表示法。
亦即n!=1×2×3×...×n。階乘亦可以遞歸方式定義:0!=1,n!=(n-1)!×n。
計(jì)算方法:
大于等于1:
任何大于等于1 的自然數(shù)n 階乘表示方法:n! =?1×2×3×...×(n-1)n或n! = n×(n-1)!
0的階乘:0!=1。
參考資料:百度百科——階乘
Java 編寫一個(gè)方法,求一個(gè)數(shù)的階乘。 n!=1×2×3×...×n,比如3!=1*2*3=6?
方法和分析見下文:
分析
1、確定基本要求,應(yīng)作為方法的限定條件或特殊情況處理
(1)規(guī)定:0!=1
(2)規(guī)定:n!中n非負(fù)
2、確定邏輯:
階乘是比較適合遞歸的思路,因?yàn)閚!=n*(n-1)!,直到求解1!作為結(jié)束
代碼(因?yàn)椴惶煜ava,可能還需要題主進(jìn)行微調(diào))
long Factorials(int n)
{
if(n0) return -1;//主要為了表示錯(cuò)誤,題主可以自定義
? 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://mengdiqiu.com.cn/a1/JavaScript/17045.html
您可能感興趣的文章
- 04-02javascript點(diǎn)線,點(diǎn)線的代碼
- 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校驗(yàn)組織機(jī)構(gòu)代碼 java校驗(yàn)組織機(jī)構(gòu)代碼是什么
- 04-02網(wǎng)頁回復(fù)java代碼 javaweb評論回復(fù)功能


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