質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

392閲覧

"project euler"の"problem 12"に関する解き方のヒント

palmkake

総合スコア9

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2018/08/29 09:51

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
Javaプログラミングに関する質問です。
webサイト"project euler" の "problem 12"に関する質問です。
問題内容は、

三角数の数列は自然数の和で表わされ, 7番目の三角数は 1 + 2 + 3 + 4 + 5 + 6 + 7 = 28 である. 三角数の最初の10項は:

1, 3, 6, 10, 15, 21, 28, 36, 45, 55, ...
となる.

最初の7項について, その約数を列挙すると, 以下のとおり.

1: 1
3: 1,3
6: 1,2,3,6
10: 1,2,5,10
15: 1,3,5,15
21: 1,3,7,21
28: 1,2,4,7,14,28

これから, 7番目の三角数である28は, 5個より多く約数をもつ最初の三角数であることが分かる.

では, 500個より多く約数をもつ最初の三角数はいくつか.

であり、私は以下のようなソースコードを書きました。
しかしながら何度実行しても結果の値が出ないため、苦戦しております。

該当のソースコード

Java

1 2package eulerpro12; 3 4public class Main { 5 6 public static boolean sosuHantei(long number) { 7 8 boolean hantei = true; 9 for(int i = 2; i <= (int)Math.sqrt((double)number); i++) { 10 if(number % i == 0) { 11 12 hantei = false; 13 14 break; 15 16 } 17 18 } 19 return hantei; 20 }> 数を代入し、それが素数ならtrueを、素数でないならfalseを返すメソッド 21 22 public static void main(String[] args) { 23 24 long triangleNum = 1; //三角数 25 26 int kosu = 1; //約数の個数 27 28 int i = 1; 29 30 //約数の個数の公式を用いて解く。 31 32 do { 33 34 i++; 35 36 triangleNum += i; 37 38 for(int j = 2; j <= triangleNum ; j++) { 39 40 if (sosuHantei(j) == false) { 41 42 continue; 43 44 } 45 46 int count = 0; //素数jで何度割り切れるか。 47 48 while(triangleNum % j == 0) { 49 50 count++; 51 52 } 53 54 kosu *= (count + 1); 55 56 } 57 58 }while(kosu <= 500); 59 60 System.out.println(triangleNum); 61 62 } 63 64}``` 65 66### 試したこと 67 68約数の公式 69「自然数Nが、素数a_1,a_2,,,,a_n を用いてN = (a_1)^p_1 × ,,, (a_n)^p_n と表せるとき、約数の個数は (p_1 + 1)×,,,×(p_n + 1) となる。」 70 71を用いて値を求めようと考えました。 72 73上記のソースコードの間違っている点について、何かしらヒントを下さると幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

メソッドsosuHanteiのところについて

java

1public static boolean sosuHantei(long number) 2{ 3 4 boolean hantei = true; 5 for(int i = 2; i <= (int)Math.sqrt((double)number); i++) { 6 if(number % i == 0) { 7 hantei = false; 8 break; 9 } 10 11 } 12 return hantei; 13} 14

となっていますが、これだと 1以下の時trueになってしまいます。numberが1以下についても判定が必要です。
また、きになったところは
1.引数の型はintで十分です。
2.Math.sqrt((double)number) -> Math.sqrt(number) のようにdoubleは書かなくてもいいです。
3.return true; return false;と書けるのでboolean hantei;は不要です。
以下のことを考慮してコードを書くとこのように書けます。

java

1public static boolean sosuHantei(int n) 2{ 3 if(n <= 1){ 4 return false; 5 } 6 for(int i = 2; i <= (int)Math.sqrt(n); i++) { 7 if(n % i == 0) { 8 return false; 9 } 10 } 11 return true; 12}

投稿2018/08/29 13:51

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

palmkake

2018/09/01 07:37

遅くなり申し訳ございません。 素数判定のメソッドについてアドバイスいただきありがとうございました。非常に参考になりました。 ベストアンサーにできず、申し訳ございませんでした。
guest

0

ベストアンサー

Java

1 while(triangleNum % j == 0) { 2 3 count++; 4 5 }

ここのループでtriangleNumは一切変化しませんので、「ループに入らない」か「無限ループになる」かのどちらかです。

投稿2018/08/29 09:54

maisumakun

総合スコア145184

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

palmkake

2018/09/01 07:35

遅くなりすみません…回答していただきありがとうございました。 無事解決いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問