前提・実現したいこと
ここに質問の内容を詳しく書いてください。
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上記のソースコードの間違っている点について、何かしらヒントを下さると幸いです。
回答2件
あなたの回答
tips
プレビュー