ホームページ Java &#&チュートリアル ケーススタディ: 階乗の計算

ケーススタディ: 階乗の計算

Jul 16, 2024 am 07:11 AM

再帰的メソッドは、それ自体を呼び出すメソッドです。多くの数学関数は再帰を使用して定義されます。簡単な例から始めましょう。数値 n の階乗は、次のように再帰的に定義できます:

0! = 1;
ん! = n × (n - 1)!; n > 0

指定された n に対して n! をどのように見つけますか? 1! を見つけるのは簡単です。0!1 であり、1!1 × 0 であることがわかっているからです。 !(n - 1)! がわかっているとすると、n × (n - 1)! を使用すると、すぐに n! を求めることができます。したがって、n! を計算する問題は、(n - 1)! を計算することに帰着します。 (n - 1)! を計算するとき、n0 になるまで同じアイデアを再帰的に適用できます。

factorial(n)n! を計算するメソッドとします。 n = 0 を指定してメソッドを呼び出すと、すぐに結果が返されます。このメソッドは、基本ケースまたは停止条件と呼ばれる最も単純なケースを解決する方法を知っています。 n > を指定してメソッドを呼び出すと、 0 の場合、問題を n - 1 の階乗を計算するための部分問題に縮小します。 部分問題は、元の問題と本質的に同じですが、より単純であるか、小さくなっています。副問題には元の問題と同じプロパティがあるため、別の引数を使用してメソッドを呼び出すことができます。これは再帰呼び出しと呼ばれます。

factorial(n) を計算するための再帰アルゴリズムは、次のように簡単に説明できます。

if (n == 0)
1 を返します;
それ以外
n * 階乗(n - 1)を返す;

メソッドは部分問題を新しい部分問題に分割し続けるため、再帰呼び出しではさらに多くの再帰呼び出しが行われる可能性があります。再帰的メソッドを終了するには、問題を最終的に停止ケースに絞り込む必要があり、その時点でメソッドは呼び出し元に結果を返します。次に、呼び出し元は計算を実行し、その結果を自身の呼び出し元に返します。このプロセスは、結果が元の呼び出し元に返されるまで続きます。元の問題は、factorial(n - 1) の結果を n に乗算することで解決できます。

以下のコードは、ユーザーに非負の整数の入力を求め、その数値の階乗を表示する完全なプログラムを提供します。

Image description

factorial メソッド (17 ~ 22 行目) は、本質的には、階乗の再帰数学的定義を Java コードに直接変換したものです。 factorial への呼び出しは、それ自体を呼び出すため再帰的です。 factorial に渡されるパラメーターは、基本ケースの 0 に達するまで減分されます。

再帰メソッドの書き方がわかりました。再帰はバックグラウンドでどのように機能するのでしょうか?以下の図は、n = 4.

から始まる再帰呼び出しの実行を示しています。

Image description

再帰呼び出しでのスタック領域の使用を下の図に示します。

Image description

ループを使用して 階乗 メソッドを実装する方が簡単で効率的です。ただし、ここでは再帰の概念を示すために再帰的 階乗 メソッドを使用します。この章の後半では、本質的に再帰的であり、再帰を使用しないと解決するのが難しいいくつかの問題を紹介します。

最終的に基本ケースに収束するような方法で再帰によって問題が軽減されない場合、または基本ケースが指定されていない場合、無限再帰が発生する可能性があります。たとえば、誤って factorial メソッドを次のように書いたとします。

パブリック 静的ロング階乗 (int n) {
n * 階乗(n - 1)を返す;
}

メソッドが無限に実行され、StackOverflowError が発生します。

このセクションで説明する例は、それ自体を呼び出す再帰メソッドを示しています。これは直接再帰として知られています。 間接再帰を作成することも可能です。これは、メソッド A がメソッド B を呼び出し、メソッド B がメソッド A を呼び出すときに発生します。再帰にはさらにいくつかのメソッドが関与する可能性もあります。たとえば、メソッド A はメソッド B を呼び出し、このメソッド C がメソッド

A を呼び出します。

以上がケーススタディ: 階乗の計算の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

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

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? 会社のセキュリティソフトウェアはアプリケーションの実行に失敗していますか?それをトラブルシューティングと解決する方法は? Apr 19, 2025 pm 04:51 PM

一部のアプリケーションが適切に機能しないようにする会社のセキュリティソフトウェアのトラブルシューティングとソリューション。多くの企業は、内部ネットワークセキュリティを確保するためにセキュリティソフトウェアを展開します。 ...

名前を数値に変換してソートを実装し、グループの一貫性を維持するにはどうすればよいですか? 名前を数値に変換してソートを実装し、グループの一貫性を維持するにはどうすればよいですか? Apr 19, 2025 pm 11:30 PM

多くのアプリケーションシナリオでソートを実装するために名前を数値に変換するソリューションでは、ユーザーはグループ、特に1つでソートする必要がある場合があります...

MapsTructを使用したシステムドッキングのフィールドマッピングの問題を簡素化する方法は? MapsTructを使用したシステムドッキングのフィールドマッピングの問題を簡素化する方法は? Apr 19, 2025 pm 06:21 PM

システムドッキングでのフィールドマッピング処理は、システムドッキングを実行する際に難しい問題に遭遇することがよくあります。システムのインターフェイスフィールドを効果的にマッピングする方法A ...

Intellijのアイデアは、ログを出力せずにSpring Bootプロジェクトのポート番号をどのように識別しますか? Intellijのアイデアは、ログを出力せずにSpring Bootプロジェクトのポート番号をどのように識別しますか? Apr 19, 2025 pm 11:45 PM

intellijideaultimatiateバージョンを使用してスプリングを開始します...

エンティティクラス変数名をエレガントに取得して、データベースクエリ条件を構築する方法は? エンティティクラス変数名をエレガントに取得して、データベースクエリ条件を構築する方法は? Apr 19, 2025 pm 11:42 PM

データベース操作にMyBatis-Plusまたはその他のORMフレームワークを使用する場合、エンティティクラスの属性名に基づいてクエリ条件を構築する必要があることがよくあります。あなたが毎回手動で...

Javaオブジェクトを配列に安全に変換する方法は? Javaオブジェクトを配列に安全に変換する方法は? Apr 19, 2025 pm 11:33 PM

Javaオブジェクトと配列の変換:リスクの詳細な議論と鋳造タイプ変換の正しい方法多くのJava初心者は、オブジェクトのアレイへの変換に遭遇します...

eコマースプラットフォームSKUおよびSPUデータベースデザイン:ユーザー定義の属性と原因のない製品の両方を考慮する方法は? eコマースプラットフォームSKUおよびSPUデータベースデザイン:ユーザー定義の属性と原因のない製品の両方を考慮する方法は? Apr 19, 2025 pm 11:27 PM

eコマースプラットフォーム上のSKUおよびSPUテーブルの設計の詳細な説明この記事では、eコマースプラットフォームでのSKUとSPUのデータベース設計の問題、特にユーザー定義の販売を扱う方法について説明します。

Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Redisキャッシュソリューションを使用して、製品ランキングリストの要件を効率的に実現する方法は? Apr 19, 2025 pm 11:36 PM

Redisキャッシュソリューションは、製品ランキングリストの要件をどのように実現しますか?開発プロセス中に、多くの場合、ランキングの要件に対処する必要があります。

See all articles