① java 階乘
同意qsmy的意見,不過樓主為什麼非用for循環而不用遞歸來實現呢?
② 用java寫的階乘
public class DoWork extends Thread {
//author by sunvins 5.14
private int type;
private static Double result = 0d;
private static boolean isOver = false;
private static Double num = 0d;
private final Double maxN = 100d;
//最大記到的整數,我測的結果,最多取171就溢出了
public DoWork(int type) {
super();
this.type = type;
}
public static void main(String[] args) {
DoWork work1 = new DoWork(1);
DoWork work2 = new DoWork(2);
work1.start();
work2.start();
}
public void run() {
while (!isOver && type == 1) {// 注意:兩個while不能合並
sumN(maxN);
}
while (num <= maxN && type == 2) {
// 讀取結果
System.out.println("result=" + result + " n=" + num);
// work1停了,work2還要讀最後一次的結果
if (num >= maxN)
break;
try {
sleep(10);// 小睡一會兒再讀
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
// 算階乘和
public void sumN(Double n) {
Double lastFactorial = 1d;
for (Double i = 1d; i <= n; i++) {
this.num = i;// 計數器,記住算到哪個數了
try {
sleep(5);// work1也要小小休息,不然太快了,work2都還來不及記,呵
} catch (InterruptedException e) {
e.printStackTrace();
}
// result += factorial(i);// 常規演算法調用
lastFactorial *= i;
result += lastFactorial; //這是優化演算法,只是不知道在這里有沒意義
}
isOver = true;
}
// 算階乘,這個是常規演算法
// public Double factorial(Double n) {
// if (n < 1)
// return 1d;
// return n * factorial(n - 1);
// }
}
③ JAVA中怎麼表示階乘
1、首先在電腦打開eclipse軟體,創建Scanner對象。
④ java階乘
主要原因是你的輸入方法寫錯了
我又給你寫了一個 ,我運行了,好用。具體如下
public class Text {
public static void main(String[] args) throws IOException{
// int i=0;
// i=i++;
// System.out.println(i);
// System.out.println(i);
// System.out.println(i+1);
// System.out.println(i);
System.out.println("請輸入一個數:");
Scanner sc=new Scanner(System.in);
int one=sc.nextInt();
int sum=1;
for(int i=one;i>0;i--){
sum*=i;
}
System.out.println(one+"!"+"="+sum);
}
}
⑤ java語言求n的階乘
staticlongcalcFactorial(intn){
if(n==1){
return1;
}else{
returnn*calcFactorial(n-1);
}
}
⑥ java中階乘怎麼表示
沒有自帶方法表示階乘,必須自己通過循環來實現
⑦ java n的階乘
無語
public class jjjj {
int pp(int n)
{
if(n<2)
return 1*n;
else
return n*pp(n-1);
}
public static void main(String args[])
{
jjjj b=new jjjj();
int d=b.pp(5);
System.out.print(d);
}
}
階乘就是利用遞歸啊。
整個程序的核心就是int pp(int n)
{
if(n<2)
return 1*n;
else
return n*pp(n-1);
}
這一段, 如果n大於2,返回n*pp(n-1)的意思,就是,任何一個N的階乘等於n*比n小1的數的階乘,打個比方,比如5的階乘等於5*(4的階乘),4的階乘等於4*(3的階乘),而1的階乘,等於1本身。
⑧ JAVA里階乘什麼意思啊
階乘是數學概念,如5的階乘是5*4*3*2*1,在java中可以通過遞歸實現.
⑨ java階乘問題
里層循環結果輸出後:即System.out.println(fact);後面加上fact = 1.0;
不然會在上一個結果的基礎上做下步運算。
⑩ 關於JAVA階乘!
答案肯定有問題撒。。你根本就沒求階乘。。
static int fuc(int n){
return n;
}
這個方法改下
static int fuc(int n){
if(n == 0) return 0;
int sum = 1;
for(int i = 1; i <= n; i++) {
sum *= i;
}
return sum;
}