国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
如何執(zhí)行Java程式?
使用各種方法的階乘範例
範例 1 – 使用基本方法
範例 2 – 使用使用者輸入
範例 3 – 使用遞歸方法
缺點
Example 4 – Using built-in Function
Conclusion –?Factorial in Java
首頁 Java java教程 Java 中的階乘

Java 中的階乘

Aug 30, 2024 pm 04:25 PM
java

在本文中,我們將了解使用 Java 程式語言編寫用於階乘計算的程式碼的各種方法。作為一種易於使用的物件導向語言,Java 是一種獨立於平臺的簡單程式語言。 Java 的編譯器和解釋器是以安全性為主要方面開發(fā)的。 Java 的應用範圍非常廣泛。

廣告 該類別中的熱門課程 JAVA 掌握 - 專業(yè)化 | 78 課程系列 | 15 次模擬測驗

開始您的免費軟體開發(fā)課程

網(wǎng)頁開發(fā)、程式語言、軟體測試及其他

階乘,符號為“!” (感嘆號),是將一個數(shù)字與所有較小的數(shù)字相乘的數(shù)學運算。例如,如果數(shù)字是 5,階乘的輸出將為 5! = 5*4*3*2*1 = 120.

如何執(zhí)行Java程式?

1.完成您的程式碼並將其另存為 (檔案名稱).java

2.開啟終端機並執(zhí)行以下 java 指令。

  • a. javac(檔名).java

3.上面的指令將產(chǎn)生一個類別檔案。

4.現(xiàn)在,執(zhí)行類別檔案。

  • a. java(檔名)

使用各種方法的階乘範例

以下是使用不同方法的不同範例:

範例 1 – 使用基本方法

接下來,我們將編寫一個簡單的階乘計算的 Java 程式。

public class Factorial
{
public static void main(String args[])
{int i, fact=1;
int number=5;
for(i=1;i<=number;i++)
{
fact=fact*i;
}
System.out.println("Factorial of "+number+" is: "+fact);
}
}

使用任意檔名和 .java 副檔名儲存上述程式碼。

代碼說明:

它從兩個變數(shù)「i」和「fact」開始,值為 1,然後「number」為 5,這是我們計算階乘的數(shù)字。我進入For循環(huán),不斷增加i的值,直到我們將它與一個數(shù)字匹配,即5。在增加的同時,每次fact的值增加,它都會相乘,並且fact被分配一個新值。

輸出:

Java 中的階乘

範例 2 – 使用使用者輸入

另一種常用的方法是我們要求使用者輸入數(shù)字進行計算,而不是預先定義它。

參考以下程式碼進行基於使用者輸入的計算:

import java.util.Scanner;
class Facto{
public static void main(String args[]) {
int q, a, fact = 1;
System.out.println("Please Enter a number:");
Scanner in = new Scanner(System.in);
q = in.nextInt();
if ( q < 0 )
System.out.println("Please enter a number greater than 0:");
else {
for ( a = 1 ; a <= q ; a++ )
fact = fact*a;
System.out.println("Factorial of "+q+" is = "+fact);
}
}
}

像前面的範例一樣保存上面的程式碼。

代碼說明:

前面的範例和上面的範例之間的主要區(qū)別在於使用者輸入;休息也是一樣。程式碼會要求計算一個數(shù)字,那麼如果使用者輸入的數(shù)字是負數(shù),即“-”中的減號,則會提示“請輸入大於0的數(shù)字:”,這很明顯,因為階乘不能計算計算為負數(shù)。現(xiàn)在,它將接受正數(shù)並繼續(xù)計算階乘,然後列印輸出,如下圖所示。

輸出:

Java 中的階乘

範例 3 – 使用遞歸方法

遞歸是程式設(shè)計世界中最有用的工具之一。遞歸基本上意味著重複使用函數(shù)。也就是說,我們不必在這裡定義額外數(shù)量的變量,這意味著我們只有兩個或更少的變數(shù)。

實現(xiàn)遞歸的一個主要原因是能夠減少程式碼長度並優(yōu)雅地降低程式的時間複雜度。遞歸方法雖然有其優(yōu)點,但也有一些缺點,從長遠來看,這些缺點可能會產(chǎn)生重大影響。

缺點

遞迴的缺點:

  • 基本上,偵錯遞歸程式碼並追蹤它是否有錯誤的步驟是相當困難的。
  • 除此之外,遞歸會使用更多內(nèi)存,因為它使用堆疊來完成任務,並透過更新的遞歸呼叫不斷累積堆疊。
  • 而且,如果實作不明智,遞歸會減慢函數(shù)的速度。
  • StackOverflowException:遞歸方法經(jīng)常由於堆疊的過度使用而拋出此異常。

參考以下程式碼:

public class FactorialExample2 {
static int factorial(int n){
if (n == 1)
return 1;
else
return(n * factorial(n-1));
}
public static void main(String[] args) {
System.out.println("Factorial of 5 is: "+factorial(5));
}
}

像我們之前那樣儲存並編譯程式。

代碼說明:

The above code starts with a single int variable and checks if it is equal to 1; if yes, it returns one, as factorial for 1 is 1. If not equal to 1, it proceeds with the recursion function. Our int value, for example, is 5, so it’ll be like “5 * factorial(5-1)”, factorial is called here for the second time, which is another call. Then it returns again with a newer int value, which is 4, “4 * factorial(4-1)”, now it’ll be the third call to the recursion method. Now, the newer int value is 3, which means “3 * factorial(3-1)”, now it’ll be the fourth call, and the value will be 2, which means “2 * factorial(2-1)”. The int value will be one in the next recursive call, which will terminate the function here. While every call was made, its value was saved in a Stack, which is a LIFO method. So, for the final Output, the result will be “5*4*3*2*1 = 120.”

Compared to other methods, Recursion is quite difficult to understand and to implement, but if understood well and implemented wisely, it is a good tool.

Output:

Java 中的階乘

It is highly recommended to use Recursion only in the case where writing an iterative code can be quite complex.

Now that we have learned various methods for implementing Factorial Calculations in Java Let’s explore a Built-in function that does the same work in a single line.

Example 4 – Using built-in Function

*) IntMath

Understanding the need for arithmetic operations over a value, a few functions specific to certain value types were written, we will see the Integer type value in work.

IntMath is a class for arithmetic calculations on an int value. IntMath class comes with a range of arithmetic operations, including factorial.

Syntax:

factorial (int n)

Conclusion –?Factorial in Java

We started with an introduction to java and how to run a java program. Then we learned about Factorial Calculation and various methods, including Recursion, to accomplish it.

Towards the end, we learned about IntMath; a Java Function primarily focused on Arithmetic operations. Java is a widely-used programming language; it comes with many features; in this article, we learned about Factorial Calculations in Java, which is a tiny aspect.

以上是Java 中的階乘的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔相應的法律責任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java Classloader在內(nèi)部如何工作 Java Classloader在內(nèi)部如何工作 Jul 06, 2025 am 02:53 AM

Java的類加載機制通過ClassLoader實現(xiàn),其核心工作流程分為加載、鏈接和初始化三個階段。加載階段由ClassLoader動態(tài)讀取類的字節(jié)碼並創(chuàng)建Class對象;鏈接包括驗證類的正確性、為靜態(tài)變量分配內(nèi)存及解析符號引用;初始化則執(zhí)行靜態(tài)代碼塊和靜態(tài)變量賦值。類加載採用雙親委派模型,優(yōu)先委託父類加載器查找類,依次嘗試Bootstrap、Extension和ApplicationClassLoader,確保核心類庫安全且避免重複加載。開發(fā)者可自定義ClassLoader,如URLClassL

現(xiàn)代爪哇的異步編程技術(shù) 現(xiàn)代爪哇的異步編程技術(shù) Jul 07, 2025 am 02:24 AM

Java支持異步編程的方式包括使用CompletableFuture、響應式流(如ProjectReactor)以及Java19 中的虛擬線程。 1.CompletableFuture通過鍊式調(diào)用提升代碼可讀性和維護性,支持任務編排和異常處理;2.ProjectReactor提供Mono和Flux類型實現(xiàn)響應式編程,具備背壓機制和豐富的操作符;3.虛擬線程減少並發(fā)成本,適用於I/O密集型任務,與傳統(tǒng)平臺線程相比更輕量且易於擴展。每種方式均有適用場景,應根據(jù)需求選擇合適工具並避免混合模型以保持簡潔性

了解Java Nio及其優(yōu)勢 了解Java Nio及其優(yōu)勢 Jul 08, 2025 am 02:55 AM

JavaNIO是Java1.4引入的新型IOAPI,1)面向緩衝區(qū)和通道,2)包含Buffer、Channel和Selector核心組件,3)支持非阻塞模式,4)相比傳統(tǒng)IO更高效處理並發(fā)連接。其優(yōu)勢體現(xiàn)在:1)非阻塞IO減少線程開銷,2)Buffer提升數(shù)據(jù)傳輸效率,3)Selector實現(xiàn)多路復用,4)內(nèi)存映射加快文件讀寫。使用時需注意:1)Buffer的flip/clear操作易混淆,2)非阻塞下需手動處理不完整數(shù)據(jù),3)Selector註冊需及時取消,4)NIO並非適用於所有場景。

在Java中使用枚舉的最佳實踐 在Java中使用枚舉的最佳實踐 Jul 07, 2025 am 02:35 AM

在Java中,枚舉(enum)適合表示固定常量集合,最佳實踐包括:1.用enum表示固定狀態(tài)或選項,提升類型安全和可讀性;2.為枚舉添加屬性和方法以增強靈活性,如定義字段、構(gòu)造函數(shù)、輔助方法等;3.使用EnumMap和EnumSet提高性能和類型安全性,因其基於數(shù)組實現(xiàn)更高效;4.避免濫用enum,如動態(tài)值、頻繁變更或複雜邏輯場景應使用其他方式替代。正確使用enum能提升代碼質(zhì)量並減少錯誤,但需注意其適用邊界。

如何在Java中正確處理異常? 如何在Java中正確處理異常? Jul 06, 2025 am 02:43 AM

處理Java中的異常關(guān)鍵在於捕獲得當、處理明確、不掩蓋問題。一要按需捕獲具體異常類型,避免籠統(tǒng)catch,優(yōu)先處理checkedexception,運行時異常應提前判斷;二要使用日誌框架記錄異常,根據(jù)類型決定重試、回滾或拋出;三要利用finally塊釋放資源,推薦try-with-resources;四要合理定義自定義異常,繼承RuntimeException或Exception,攜帶上下文信息便於調(diào)試。

Java中的單例設(shè)計模式是什麼? Java中的單例設(shè)計模式是什麼? Jul 09, 2025 am 01:32 AM

單例設(shè)計模式在Java中通過私有構(gòu)造器和靜態(tài)方法確保一個類只有一個實例並提供全局訪問點,適用於控制共享資源的訪問。實現(xiàn)方式包括:1.懶加載,即首次請求時才創(chuàng)建實例,適用於資源消耗大且不一定需要的情況;2.線程安全處理,通過同步方法或雙重檢查鎖定確保多線程環(huán)境下只創(chuàng)建一個實例,並減少性能影響;3.餓漢式加載,在類加載時直接初始化實例,適合輕量級對像或可接受提前初始化的場景;4.枚舉實現(xiàn),利用Java枚舉天然支持序列化、線程安全及防止反射攻擊的特性,是推薦的簡潔可靠方式。不同實現(xiàn)方式可根據(jù)具體需求選

什麼是匿名的內(nèi)部班級? 什麼是匿名的內(nèi)部班級? Jul 07, 2025 am 02:18 AM

匿名內(nèi)部類在Java中用於即時創(chuàng)建子類或?qū)崿F(xiàn)接口,常用於覆蓋方法以實現(xiàn)特定目的,如GUI應用中的事件處理。其語法形式為new接口或類後直接定義類體,並要求訪問的局部變量必須是final或等效不可變的。它們雖便捷但不宜過度使用,尤其在邏輯複雜時,可用Java8 的Lambda表達式替代。

Java字符串與StringBuilder vs StringBuffer Java字符串與StringBuilder vs StringBuffer Jul 09, 2025 am 01:02 AM

String不可變,StringBuilder可變且非線程安全,StringBuffer可變且線程安全。 1.String一旦創(chuàng)建內(nèi)容不可修改,適合少量拼接;2.StringBuilder適合單線程頻繁拼接,性能高;3.StringBuffer適合多線程共享場景,但性能略低;4.合理設(shè)置初始容量、避免循環(huán)中用String拼接能提升性能。

See all articles