この記事では、階乗計(jì)算を目的として Java プログラミング言語(yǔ)でコードを記述するさまざまな方法について學(xué)びます。使いやすいオブジェクト指向言語(yǔ)の 1 つである Java は、プラットフォームに依存せず、シンプルなプログラミング言語(yǔ)です。 Java のコンパイラとインタプリタは、セキュリティを主要な側(cè)面として開発されました。 Javaにはさまざまな応用範(fàn)囲があります。
広告 このカテゴリーの人気コース JAVA マスタリー - スペシャライゼーション | 78 コース シリーズ | 15 回の模擬テスト無(wú)料ソフトウェア開発コースを始めましょう
Web 開発、プログラミング言語(yǔ)、ソフトウェア テスト、その他
階乗、「!」で記號(hào)化(感嘆符) は、數(shù)値とそれより小さいすべての數(shù)値を乗算する數(shù)學(xué)演算です。たとえば、數(shù)値が 5 の場(chǎng)合、階乗の出力は 5 になります。 = 5*4*3*2*1 = 120.
Java プログラムを?qū)g行するには?
1.コードを完成させ、(ファイル名).java
として保存します。2.ターミナルを開き、次の Java コマンドを?qū)g行します。
- a. javac (ファイル名).java
3.上記のコマンドはクラス ファイルを生成します。
4.次に、クラスファイルを?qū)g行します。
- a. java (ファイル名)
さまざまな手法を使用した階乗の例
以下は、さまざまなメソッドを使用したさまざまな例です:
例 1 – 基本的な方法の使用
次に、階乗計(jì)算用の簡(jiǎn)単な 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 拡張子を付けて保存します。
コードの説明:
これは、値 1 の 2 つの変數(shù)「i」と「fact」で始まり、次に階乗を計(jì)算するための數(shù)値である 5 の「number」で始まりました。 For ループに入り、數(shù)値 (5) と一致するまで i の値を増やし続けました。増加中、ファクトの値が増加するたびに乗算され、ファクトに新しい値が割り當(dāng)てられます。
出力:
例 2 – ユーザー入力の使用
もう 1 つの一般的に使用される方法は、計(jì)算のために數(shù)値を事前に定義するのではなく、ユーザーの入力を求める方法です。
ユーザー入力ベースの計(jì)算については、以下のコードを參照してください:
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); } } }
前の例で行ったように、上記のコードを保存します。
コードの説明:
前の例と上記の例の主な違いは、ユーザー入力です。殘りも同じです。コードは數(shù)値の計(jì)算を要求し、ユーザーが入力した數(shù)値が「-」つまりマイナスの場(chǎng)合は、「0 より大きい數(shù)値を入力してください:」というプロンプトが表示されます。これは、階乗を計(jì)算できないことは明らかです。負(fù)の數(shù)について計(jì)算されます。これで、正の數(shù)が受け入れられ、階乗の計(jì)算が続行され、以下の畫像に示すように出力が印刷されます。
出力:
例 3 – 再帰メソッドの使用
再帰は、プログラミングの世界で最も便利なツールの 1 つです。再帰とは基本的に関數(shù)を再利用することを意味します。いわば、ここでは余分な數(shù)の変數(shù)を定義する必要はありません。つまり、変數(shù)は 2 つ以下だけになります。
再帰を?qū)g裝する主な理由は、コードの長(zhǎng)さを短縮し、プログラムの時(shí)間の複雑さをエレガントに軽減できることです。再帰法には利點(diǎn)もありますが、長(zhǎng)期的には大きな影響を與える可能性のある欠點(diǎn)もいくつかあります。
デメリット
再帰の欠點(diǎn):
- 基本的に、再帰コードをデバッグし、エラーが発生したステップをトレースすることは非常に困難です。
- それ以外に、再帰はタスクを完了するためにスタックを使用し、新しい再帰呼び出しでスタックを追加し続けるため、より多くのメモリを使用します。
- また、賢く実裝しないと、再帰によって関數(shù)の速度が低下する可能性があります。
- StackOverflowException: スタックの過剰使用が原因で、再帰的メソッドがこの例外をスローすることがよくあります。
以下のコードを參照してください:
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:
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の階乗の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

ホットAIツール

Undress AI Tool
脫衣畫像を無(wú)料で

Undresser.AI Undress
リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover
寫真から衣服を削除するオンライン AI ツール。

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版
中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1
強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック

Laravelは、ネイティブSQLクエリの使用をサポートしていますが、安全性を確保するためにパラメーターバインディングを優(yōu)先する必要があります。 1。DB:: Select()を使用して、SQL注入を防ぐためにパラメーターバインディングを使用して選択クエリを?qū)g行します。 2。db:: update()を使用して更新操作を?qū)g行し、影響を受ける行の數(shù)を返します。 3。DB::挿入()を使用してデータを挿入します。 4。db:: delete()を使用してデータを削除します。 5。DB:: Statement()を使用して、Create、Alterなどの結(jié)果セットなしでSQLステートメントを?qū)g行します。 6. QueryBuilderでWhereraw、SelectRaw、およびその他の方法を使用して、ネイティブ表現(xiàn)を組み合わせてセキュリティを改善することをお?jiǎng)幛幛筏蓼?/p>

Junit5とMockitoを使用して、単體テストの依存関係を効果的に分離します。 1. @mockを介して模擬オブジェクトを作成します。@injectmocksテスト済みインスタンスを挿入@extendwithを有効にします。 2。when()。sonreturn()を使用してシミュレーションの動(dòng)作を定義し、()を検証してメソッド呼び出しとパラメーターの數(shù)を確認(rèn)します。 3。例外シナリオをシミュレートし、エラー処理を確認(rèn)できます。 4.コンストラクターの注入を推奨し、過剰なシミュレーションを避け、テスト原子性を維持します。 5。ASSERTALL()を使用してアサーションをマージし、@Nestedはテストシナリオを整理して、テストの保守性と信頼性を向上させます。

テーブルレイアウト:固定は、レイアウトに影響するコンテンツを避けるために、最初の行のセル幅によってテーブル列の幅を強(qiáng)制的に決定します。 1.テーブルレイアウトの設(shè)定:テーブル幅を修正して指定します。 2.最初の行th/tdの特定の列幅比を設(shè)定します。 3。ホワイトスペースを使用:Nowrap、Overflow:Hidden and Text-Overflow:Ellipsisを使用してテキストオーバーフローを制御します。 4。安定したレイアウトと高性能レンダリングを必要とするバックグラウンド管理、データレポート、およびその他のシナリオに適用できます。これは、レイアウトジッターを効果的に防止し、レンダリング効率を向上させることができます。

json.loads()は、JSON文字列をPythonデータ構(gòu)造に解析するために使用されます。 1.入力は二重引用符で包まれた文字列でなければならず、ブール値は真/falseです。 2。NULL→なし、オブジェクト→DICT、配列→リストなどの自動(dòng)変換をサポートします。 3. APIで返されるJSON文字列を処理するためによく使用されます。たとえば、response_stringは、json.loads()で解析した後に直接アクセスできます。それを使用する場(chǎng)合、JSON形式が正しいことを確認(rèn)する必要があります。そうしないと、例外がスローされます。

選択することは、shoseTheatheApsoSOFRISTEXTYPEBASEDONUSECASE、TINGASSINGLEFIELD、化合物、マルチケイ、テキスト、GEOSPATIAL、ORTTLINDEXES.2.APPLYTHEESRRULEWHENCREATINGCOMPoundExes

Mavenは、Javaプロジェクト管理と建設(shè)の標(biāo)準(zhǔn)ツールです。答えは、POM.xmlを使用してプロジェクト構(gòu)造、依存関係管理、建設(shè)ライフサイクルの自動(dòng)化、プラグイン拡張機(jī)能を標(biāo)準(zhǔn)化するという事実にあります。 1. pom.xmlを使用して、GroupID、artifactid、バージョン、依存関係を定義します。 2。MVNCLEAN、コンパイル、テスト、パッケージ、インストール、展開などのマスターコアコマンド。 3.依存関係管理と除外を使用して、依存関係バージョンと競(jìng)合を管理します。 4.マルチモジュールプロジェクト構(gòu)造を通じて大規(guī)模なアプリケーションを整理し、親POMによって均一に管理されます。 5。

Pythonでは、関數(shù)引數(shù)の転送は「オブジェクト參照を渡す」、つまり1です??蓧浈芝弗Д龋ē辚攻趣滢o書など)の場(chǎng)合、関數(shù)內(nèi)のin-situ変更(付録など)は元のオブジェクトに直接影響します。 2。不変のオブジェクト(整數(shù)、文字列など)の場(chǎng)合、元のオブジェクトを関數(shù)で変更することはできず、再割り當(dāng)ては新しいオブジェクトのみを作成します。 3.パラメーターは、參照のコピーを渡します。変數(shù)が関數(shù)(LST = [...]など)で反省されている場(chǎng)合、元のオブジェクトとの接続は影響を受けず、外部変數(shù)は影響を受けません。したがって、変更可能なオブジェクトを変更すると元のデータに影響しますが、不変のオブジェクトと再割り當(dāng)てはそうではありません。これは、関數(shù)內(nèi)の変更後にリストが外部から表示される理由を説明しますが、整數(shù)の変更はローカルでのみです。
