2019.03.20

階乗

階乗とは

階乗とは1からnの全ての自然数の積のことで、

n!

と書きます。

n!は1~nの掛け算なので、

nx(n-1)x(n-2)x … 3x2x1

となります。n=0の場合、

0!=1

と定義されます。

また、nがマイナスの場合には計算できません。

次に、0!=1の理由について説明します。4の階乗から1の階乗の計算を順を追って見ていくと、

4!=4x3x2x1=24
3!=3x2x1=6
2!=2x1=2
1!=1=1

となります。

別の書き方をすると、

3!=4!÷4
2!=3!÷3
1!=2!÷2

と書け

n!=(n+1)!÷(n+1)

であることがわかります。

それでは0!はどうでしょう。

n!=(n+1)!÷(n+1)

に0を代入すると

0!=(0+1)!÷(0+1)=1÷1

となり、

0!=1

となることがわかります。

Javaソースコード - for文を使う

ここで、階乗を計算するJavaソースコードを紹介します。

for文で1からnの値の積を求める方法で階乗を計算しています。

Factorial1.java

001
002
003
004
005
006
007
008
009
010
011
012
013
014
015
016
017
018
019
020
021
022
023
024
025
026
027
028
029
030
031
032
033
034
035
036
037
038
039
040
041
042
043
044
045
046
047
048
049
public class Factorial1 {
	// 階乗メソッド
	static int factorial( int n )
	{
		// nがマイナスの場合、nを戻す
		if ( 0 > n ) return n;

		// nが1の場合、0を戻す(0!=1)
		if ( 0 == n ) return 1;
		
		// nが1以上の場合の処理
		int ans = 1;
		for ( int i = 1; i <= n; ++ i ) {
			ans = ans * i;
		}

		// 結果を戻す
		return ans;
	}


	// メイン
	public static void main( String[] args ) {
		// 変数宣言
		int n;	// 階乗を求める値

		// 入力した引数が1以上かを調べる
		if ( 1 > args.length ) {
			// 入力した引数が1未満の場合、使用方法を表示する
			System.out.println( 
				"Factrial1 [階乗を求める値n]" );
			return;
		}

		try {
			// 引数を変換し、変数nに代入
			n =  Integer.valueOf( args[ 0 ] );
		}
		catch( NumberFormatException ne )
		{
			System.out.println( "引数が不正です" );
			return;
		}

		// 階乗メソッドの呼び出し n!
		int ans = factorial( n );
		System.out.println( n + "の階乗は" + ans + "です" );
	}
}

コンパイル ソースコードが「ANSI」の場合

C:\talavax\javasample>javac -encoding sjis Factorial1.java

コンパイル ソースコードが「UTF-8」の場合

C:\talavax\javasample>javac Factorial1.java

実行

C:\talavax\javasample>java Factorial1 5

実行結果

5の階乗は120です

1つ目の引数に5を渡して、5!を求めています。

Javaソースコード - 再帰

Factorial2.java

001
002
003
004
005
006
007
008
009
010
011
012
013
014
015
016
017
018
019
020
021
022
023
024
025
026
027
028
029
030
031
032
033
034
035
036
037
038
039
040
041
042
043
public class Factorial2 {
	// 階乗メソッド(再帰版)
	static int factorial( int n )
	{
		// nがマイナスの場合、nを戻す
		if ( 0 > n ) return n;

		// nが1の場合、0を戻す(0!=1)
		if ( 0 == n ) return 1;

		// factorialをfactorialメソッド内で呼ぶ(再帰)		
		return n * factorial( n - 1 );
	}


	// メイン
	public static void main( String[] args ) {
		// 変数宣言
		int n;	// 階乗を求める値

		// 入力した引数が1以上かを調べる
		if ( 1 > args.length ) {
			// 入力した引数が1未満の場合、使用方法を表示する
			System.out.println( 
				"Factrial1 [階乗を求める値n]" );
			return;
		}

		try {
			// 引数を変換し、変数nに代入
			n =  Integer.valueOf( args[ 0 ] );
		}
		catch( NumberFormatException ne )
		{
			System.out.println( "引数が不正です" );
			return;
		}

		// 階乗メソッドの呼び出し n!
		int ans = factorial( n );
		System.out.println( n + "の階乗は" + ans + "です" );
	}
}

コンパイル ソースコードが「ANSI」の場合

C:\talavax\javasample>javac -encoding sjis Factorial2.java

コンパイル ソースコードが「UTF-8」の場合

C:\talavax\javasample>javac Factorial2.java

実行

C:\talavax\javasample>java Factorial2 5

実行結果

5の階乗は120です

1つ目の引数に5を渡して、5!を求めています。

for文と使った方法と、再帰を使った方法で同じ結果が出力されます。階乗計算に再帰を使う必要はないと思っているのですが、階乗メソッド再帰を理解するためには良い例題です。参考にしてください。

ちなみに、これらのプログラムの中の階乗を計算するメソッド引数にマイナスの値が渡されたときに、引数の値をそのまま戻すようにしています。

以上です。

関連コンテンツ

基本的な計算である足し算(加法)/引き算(減法)/掛け算(乗法)/割り算(除法)を行うプログラム作成。

2020.03.23

処理を繰り返すために使用するfor文について解説しています。

2020.03.23

条件式を判断して処理を分岐する方法を詳しく説明しています。

2023.03.20

メソッドを抜けるときに使用するreturn文について説明しています。

2020.03.20

Javaのmainメソッドで受け取るパラメータについて解説しています。

2017.09.26

mainメソッドで受け取るパラメータの数の取得の仕方について解説しています。

2019.05.14

変数やクラスに格納されている値をコンソール出力する方法は?

2020.03.23

プログラムの最初に実行されるメソッドは?

2022.12.13

プログラミングで使う変数って何?

2020.03.23

Javaのプログラムを書いてみませんか?プログラムの書き方をくわしく説明しています。

2020.03.23

「Javaソースコード」から実行可能な「オブジェクトコード」に変換する方法をくわしく説明しています。

2020.03.23

Javaのプログラムを作ってみませんか?プログラミングに必要なものの用意から実行までを説明しています。

2020.03.23

Javaの学習に役立つソースコードを多数紹介しています。是非、ご覧ください。

2022.09.10

Swingパッケージを使ってグラフィック表示を行う方法を解説しています。

2020.03.23

画像フォーマット形式・色・大きさ・傾きなどの変更、特定の図形(文字・記号など)を見つけたり、取り出したりする画像処理について詳しく解説。

2015.11.29

繰り返し処理を使ったJavaのソースコードサンプルを紹介しています。

2020.03.23

配列を使うJavaソースコードを多数紹介しています。

2021.05.18

数学に関係するJavaのメソッドやソースコードなどを紹介しています。

2022.10.25

三角形、台形、円などいろいろな図形の面積を計算するプログラムを紹介しています。詳しくは、記事をご覧ください。

2021.05.18

StringクラスとStringBuilderクラスを利用したプログラミングの仕方を紹介しています。

2016.12.16

Javaを使った簡単な応用プログラム(生年月日から年齢を計算プログラムなど)を紹介しています。

2022.07.07

プログラミング、ITに関する用語をまとめています。

2022.10.17

日本で使われてきた伝統文様「和柄」について解説しています。

2022.07.27

自然数と整数って何が違う?

2020.03.23

プログラミング言語とは?種類や特徴について説明しています。

2022.08.03

メソッドの定義方法を詳しく解説しています。Javaのサンプルソースコードを使った説明もあります。

2020.03.23

「ゆるゆるプログラム」のコンテンツを紹介しています。興味のある方はこの記事をご覧ください。

2020.03.23

広告