99 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 595608ff8bcd7a50bd490181
 | |
| title: ヘイルストーンシーケンス (コラッツ数列)
 | |
| challengeType: 5
 | |
| forumTopicId: 302279
 | |
| dashedName: hailstone-sequence
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| ヘイルストーンシーケンスの数列は、正の整数 `n` を初期値として生成され、n は以下のいずれかになります:
 | |
| 
 | |
| - `n` が `1` の場合、この数列は終了します
 | |
| - `n` が`even` (偶数) の場合、シーケンスの 次の `n` は `= n/2`
 | |
| - `n` が `odd` (奇数) の場合、シーケンスの次の `n` は `= (3 * n) + 1`
 | |
| 
 | |
| コラッツの予想 (証明されていない) では、初期値が何であれ、ヘイルストーンシーケンスは常に終了するとされています。
 | |
| 
 | |
| ヘイルストーンシーケンスは、ヘイルストーン数としても知られています (値が通常は雲の中の雹 (ヘイルストーン) のように何度も上下するためです)。 あるいはコラッツ数列とも呼ばれます。
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| 1. ある数値のヘイルストーンシーケンスを生成するルーチンを作成してください。
 | |
| 2. この関数は、最長のヘイルストーンシーケンスを取る `limit` 未満の数とそのシーケンスの長さを持つ配列を返す必要があります。 (ただし、実際のシーケンスは表示しないでください!)
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| `hailstoneSequence` は関数とします。
 | |
| 
 | |
| ```js
 | |
| assert(typeof hailstoneSequence === 'function');
 | |
| ```
 | |
| 
 | |
| `hailstoneSequence(30)` は配列を返す必要があります。
 | |
| 
 | |
| ```js
 | |
| assert(Array.isArray(hailstoneSequence(30)));
 | |
| ```
 | |
| 
 | |
| `hailstoneSequence(30)` は`[27, 112]`を返す必要があります。
 | |
| 
 | |
| ```js
 | |
| assert.deepEqual(hailstoneSequence(30), [27, 112]);
 | |
| ```
 | |
| 
 | |
| `hailstoneSequence(50000)` は`[35655, 324]`を返す必要があります。
 | |
| 
 | |
| ```js
 | |
| assert.deepEqual(hailstoneSequence(50000), [35655, 324]);
 | |
| ```
 | |
| 
 | |
| `hailstoneSequence(100000)` は`[77031, 351]`を返す必要があります。
 | |
| 
 | |
| ```js
 | |
| assert.deepEqual(hailstoneSequence(100000), [77031, 351]);
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```js
 | |
| function hailstoneSequence(limit) {
 | |
|   const res = [];
 | |
| 
 | |
| 
 | |
|   return res;
 | |
| }
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```js
 | |
| function hailstoneSequence (limit) {
 | |
|   function hailstone(n) {
 | |
|     const seq = [n];
 | |
|     while (n > 1) {
 | |
|       n = n % 2 ? 3 * n + 1 : n / 2;
 | |
|       seq.push(n);
 | |
|     }
 | |
|     return seq;
 | |
|   }
 | |
| 
 | |
|   let n = 0;
 | |
|   let max = 0;
 | |
|   for (let i = limit; --i;) {
 | |
|     const seq = hailstone(i);
 | |
|     const sLen = seq.length;
 | |
| 
 | |
|     if (sLen > max) {
 | |
|       n = i;
 | |
|       max = sLen;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   return [n, max];
 | |
| }
 | |
| ```
 |