2022.07.06

完全数

はじめに

完全数とは、その数字自身を除く約数の和がその数字自身に等しい自然数のことです。ピタゴラスが名づけた数の1つです。

完全数の例です。

6=1+2+3
28=1+2+4+7+14

与えられた自然数Xを1からX/2までの整数で割っていき、余りが0の値の和を計算し、その値がXと等しければXは完全数となります。

Javaソースコード

以下は、完全数を見つけるJavaソースコードで、2から10000の範囲で完全数を見つけるものです。

PerfectNumber.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
public class PerfectNumber {
	// 完全数かを判定するメソッド
	private static boolean isPerfectNumber( int n )
	{
		// 2未満は完全数ではない
		if ( 2 > n ) return false;

		// 和を計算
		int sum = 0;
		for ( int i = 1; i <= n / 2; i ++ )
		{
			if ( 0 == ( n % i ) )
				sum += i;
		}

		// 判定
		// 和sumと元の値nが不一致なので完全数である
		if ( sum == n ) return true;

		// 和sumと元の値nが不一致なので完全数ではない
		return false;
	}

	// メイン
	public static void main( String[] args ) {
		// 2から10000の範囲で、完全数を見つける
		for ( int i = 2; i <= 10000; i ++ )
		{
			if ( isPerfectNumber( i ) )
				System.out.println( i );
		}
	}
}

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

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

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

C:\talavax\javasample>javac PerfectNumber.java

実行

C:\talavax\javasample>java PerfectNumber

実行結果

6
28
496
8128

Javaソースコードの解説

ここからは、このソースコードを上から順番に解説していきます。

001
public class PerfectNumber {

クラス名を、PerfectNumberとしています。

002
003
004
	// 完全数かを判定するメソッド
	private static boolean isPerfectNumber( int n )
	{

指定した整数nが完全数かを判定するメソッドisPerfectNumberです。nの値が完全数の場合、このメソッドtrueを戻します。

005
006
		// 2未満は完全数ではない
		if ( 2 > n ) return false;

指定した整数nが2未満の場合、和の計算をすることなくfalseを戻します。

008
009
		// 和を計算
		int sum = 0;

和を格納する変数sumに0を代入しています。

010
011
		for ( int i = 1; i <= n / 2; i ++ )
		{

for文を使って、1からn/2のループを作っています。整数nはn/2より大きい数字で割り切れないので、n/2までのループにしています。

012
013
			if ( 0 == ( n % i ) )
				sum += i;

整数nをiで割り、その余りが0の場合、変数sumにiを足しています。

016
017
018
		// 判定
		// 和sumと元の値nが不一致なので完全数である
		if ( sum == n ) return true;

整数nとsumが同じであれば完全数なので、return文trueを戻します。

020
021
		// 和sumと元の値nが不一致なので完全数ではない
		return false;

整数nとsumが違えば完全数ではないので、return文falseを戻します。

このmainメソッドからプログラムを実行します。

024
025
	// メイン
	public static void main( String[] args ) {

標準入力System.inを使って、Scannerクラスのscanを初期化しています。

026
027
028
029
030
031
		// 2から10000の範囲で、完全数を見つける
		for ( int i = 2; i <= 10000; i ++ )
		{
			if ( isPerfectNumber( i ) )
				System.out.println( i );
		}

変数iを2から10000までのループを作成し、その値を完全数判定メソッドisPerfectNumberに渡しています。その結果、完全数と判定されたiをコンソール出力しています。

以上です。

関連コンテンツ

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

2020.03.20

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

2020.03.23

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

2020.03.23

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

2020.03.23

割り算で割り切れずに残った端数を剰余(余り)といいます。この剰余の計算をJavaのソースコードを使って解説しています。

2020.03.23

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

2020.03.23

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

2023.03.20

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

2020.03.23

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

2022.12.13

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

2020.03.23

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

2020.03.23

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

2020.03.23

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

2022.08.03

Javaプログラムの構成について解説しています。詳しくは、こちらをご覧ください。

2020.03.23

割り算で「割り切れる」、「割り切れない」ってどういうこと?

繰り返し処理の作り方を解説しています。

2016.03.02

for文で変数名iがよく使われる理由について説明しています。興味のある方は是非。

2022.08.29

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

2020.03.23

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

2022.09.10

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

2022.07.07

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

2020.03.23

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

2015.11.29

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

2021.05.18

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

2021.05.18

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

2020.03.23

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

2022.10.25

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

2016.12.16

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

2022.07.27

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

2022.10.17

広告