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

目次
Java プログラムを?qū)g行するには?
さまざまな手法を使用した階乗の例
例 1 – 基本的な方法の使用
例 2 – ユーザー入力の使用
例 3 – 再帰メソッドの使用
デメリット
Example 4 – Using built-in Function
Conclusion –?Factorial in Java

Javaの階乗

Aug 30, 2024 pm 04:25 PM
java

この記事では、階乗計(jì)算を目的として Java プログラミング言語でコードを記述するさまざまな方法について學(xué)びます。使いやすいオブジェクト指向言語の 1 つである Java は、プラットフォームに依存せず、シンプルなプログラミング言語です。 Java のコンパイラとインタプリタは、セキュリティを主要な側(cè)面として開発されました。 Javaにはさまざまな応用範(fàn)囲があります。

広告 このカテゴリーの人気コース JAVA マスタリー - スペシャライゼーション | 78 コース シリーズ | 15 回の模擬テスト

無料ソフトウェア開発コースを始めましょう

Web 開発、プログラミング言語、ソフトウェア テスト、その他

階乗、「!」で記號(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)てられます。

出力:

Javaの階乗

例 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ì)算が続行され、以下の畫像に示すように出力が印刷されます。

出力:

Javaの階乗

例 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:

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の階乗の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國(guó)語版

SublimeText3 中國(guó)語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Java Classloadersの動(dòng)作方法 Java Classloadersの動(dòng)作方法 Jul 06, 2025 am 02:53 AM

Javaのクラスロードメカニズムはクラスローダーを介して実裝されており、そのコアワークフローは、読み込み、リンク、初期化の3つの段階に分けられます。ローディングフェーズ中、クラスローダーはクラスのバイトコードを動(dòng)的に読み取り、クラスオブジェクトを作成します。リンクには、クラスの正しさの確認(rèn)、靜的変數(shù)へのメモリの割り當(dāng)て、およびシンボル?yún)⒄栅谓馕訾蓼欷蓼?。初期化は、靜的コードブロックと靜的変數(shù)割り當(dāng)てを?qū)g行します。クラスの読み込みは、親クラスローダーに優(yōu)先順位を付けてクラスを見つけ、ブートストラップ、拡張機(jī)能、およびアプリケーションクラスローダーを順番に試して、コアクラスライブラリが安全であり、重複した負(fù)荷を回避することを確認(rèn)します。開発者は、urlclasslなどのクラスローダーをカスタマイズできます

現(xiàn)代のジャワの非同期プログラミング技術(shù) 現(xiàn)代のジャワの非同期プログラミング技術(shù) Jul 07, 2025 am 02:24 AM

Javaは、Java19での完了可能なストリーム(ProjectReactorなど)、仮想スレッドの使用など、非同期プログラミングをサポートしています。 1.CompletableFutureチェーンコールを通じてコードの読みやすさとメンテナンスを改善し、タスクオーケストレーションと例外処理をサポートします。 2。ProjectReactorは、バックプレッシャーメカニズムとリッチ演算子を備えた応答性プログラミングを?qū)g裝するためのモノとフラックスタイプを提供します。 3.仮想スレッドは、同時(shí)性コストを削減し、I/O集約型タスクに適しており、従來のプラットフォームスレッドよりも軽量で拡張が容易です。各方法には適用可能なシナリオがあり、適切なツールをお客様のニーズに応じて選択する必要があり、混合モデルはシンプルさを維持するために避ける必要があります

Java Nioとその利點(diǎn)を理解する Java Nioとその利點(diǎn)を理解する Jul 08, 2025 am 02:55 AM

Javanioは、Java 1.4によって導(dǎo)入された新しいIoapiです。 1)バッファとチャネルを?qū)澫螭趣筏皮い蓼埂?)バッファ、チャネル、セレクターのコアコンポーネント、3)ノンブロッキングモードをサポートし、4)従來のIOよりも効率的に並行接続を処理します。その利點(diǎn)は、次のことに反映されます。1)非ブロッキングIOはスレッドオーバーヘッドを減らし、2)データ送信効率を改善し、3)セレクターがマルチプレックスを?qū)g現(xiàn)し、4)メモリマッピングはファイルの読み取りと書き込みを速めます。注:1)バッファのフリップ/クリア操作は混亂しやすく、2)不完全なデータをブロックせずに手動(dòng)で処理する必要があります。3)セレクター登録は時(shí)間內(nèi)にキャンセルする必要があります。4)NIOはすべてのシナリオに適していません。

Javaで酵素を使用するためのベストプラクティス Javaで酵素を使用するためのベストプラクティス Jul 07, 2025 am 02:35 AM

Javaでは、列挙は固定定數(shù)セットを表すのに適しています。ベストプラクティスには以下が含まれます。1。列挙を使用して固定狀態(tài)またはオプションを表して、タイプの安全性と読みやすさを改善します。 2.フィールド、コンストラクター、ヘルパーメソッドなどの定義など、柔軟性を高めるために、酵素にプロパティとメソッドを追加します。 3. enummapとEnumsetを使用して、パフォーマンスとタイプの安全性を向上させ、配列に??基づいてより効率的であるためです。 4.動(dòng)的値、頻繁な変更、複雑なロジックシナリオなどの列挙の悪用を避けてください。これらは他の方法に置き換える必要があります。列挙の正しい使用は、コードの品質(zhì)を改善し、エラーを減らすことができますが、適用される境界に注意を払う必要があります。

Javaで例外を適切に処理する方法は? Javaで例外を適切に処理する方法は? Jul 06, 2025 am 02:43 AM

Javaの例外を処理するための鍵は、それらをキャッチし、それらを明確に処理し、問題を隠さないことです。まず、必要に応じて特定の例外タイプをキャッチし、一般的なキャッチを避け、CheckEdexceptionsを優(yōu)先順位付けする必要があります。ランタイムの例外は事前に審査する必要があります。次に、ログフレームワークを使用して例外を記録し、タイプに基づいて再試行、ロールバック、またはスローする必要があります。第三に、最終的なブロックを使用してリソースをリリースする必要があり、リソース付きの試行をお?jiǎng)幛幛工氡匾ⅳ辘蓼埂5?に、カスタムの例外を合理的に定義し、runtimeexceptionまたは例外を継承し、簡(jiǎn)単にデバッグするためのコンテキスト情報(bào)を伝達(dá)する必要があります。

JavaのSingletonデザインパターンとは何ですか? JavaのSingletonデザインパターンとは何ですか? Jul 09, 2025 am 01:32 AM

JavaのSingleton Design Patternは、クラスに1つのインスタンスしかないことを保証し、プライベートコンストラクターと靜的方法を介したグローバルアクセスポイントを提供することを保証します。これは、共有リソースへのアクセスを制御するのに適しています。実裝方法には以下が含まれます。1。レイジーロード、つまり、インスタンスは最初のリクエストが要求されたときにのみ作成されます。これは、リソースの消費(fèi)が高く、必ずしも必要ではない狀況に適しています。 2。スレッドセーフ処理。同期方法または再確認(rèn)ロックを介して、マルチスレッド環(huán)境で1つのインスタンスのみが作成され、パフォーマンスへの影響が低下するようにします。 3.クラスの読み込み中にインスタンスを直接初期化するHungry Loadingは、事前に初期化できる軽量オブジェクトまたはシナリオに適しています。 4.列挙の実裝は、Java列挙を使用してシリアル化、スレッドの安全性をサポートし、反射攻撃を防止することは、推奨される簡(jiǎn)潔で信頼できる方法です。特定のニーズに応じて、さまざまな実裝方法を選択できます

匿名のインナークラスとは何ですか? 匿名のインナークラスとは何ですか? Jul 07, 2025 am 02:18 AM

匿名の內(nèi)部クラスは、Javaでサブクラスを作成したり、その場(chǎng)でインターフェイスを?qū)g裝するために使用され、GUIアプリケーションでのイベント処理など、特定の目的を達(dá)成するための方法をオーバーライドするためによく使用されます。その構(gòu)文フォームは、クラス本體を直接定義する新しいインターフェイスまたはクラスであり、アクセスされるローカル変數(shù)が最終的または同等の不変でなければならないことを要求します。それらは便利ですが、使いすぎてはいけません。特にロジックが複雑な場(chǎng)合は、Java8のLambda式に置き換えることができます。

Java String vs StringBuilder vs StringBuffer Java String vs StringBuilder vs StringBuffer Jul 09, 2025 am 01:02 AM

文字列は不変、StringBuilderは可変で非スレッドセーフ、StringBufferはMutableとThread-Safeです。 1.文字列のコンテンツが作成されると、少量のスプライシングに適しています。 2。StringBuilderは、単一のスレッドの頻繁なスプライシングに適しており、パフォーマンスが高くなっています。 3。StringBufferは、マルチスレッドの共有シナリオに適していますが、パフォーマンスがわずかに低くなっています。 4.初期容量を合理的に設(shè)定し、ループで文字列スプライシングを使用することはパフォーマンスを向上させることができます。

See all articles