1.7 KiB
1.7 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
5a23c84252665b21eecc7ec1 | 各位の2乗を繰り返す | 5 | 302291 | iterated-digits-squaring |
--description--
自然数 (0より大きい整数) の各位を2乗して足すと、やがて、常に1か89になります。
15 -> 26 -> 40 -> 16 -> 37 -> 58 -> 89 7 -> 49 -> 97 -> 130 -> 10 -> 1
--instructions--
パラメータとして数値を取り、上記プロセスを実行した後に 1 または 89 を返す関数を記述してください。
--hints--
iteratedSquare
は関数とします。
assert(typeof iteratedSquare == 'function');
iteratedSquare(4)
は数値を返す必要があります。
assert(typeof iteratedSquare(4) == 'number');
iteratedSquare(4)
は89
を返す必要があります。
assert.equal(iteratedSquare(4), 89);
iteratedSquare(7)
は1
を返す必要があります。
assert.equal(iteratedSquare(7), 1);
iteratedSquare(15)
は89
を返す必要があります。
assert.equal(iteratedSquare(15), 89);
iteratedSquare(20)
は89
を返す必要があります。
assert.equal(iteratedSquare(20), 89);
iteratedSquare(70)
は1
を返す必要があります。
assert.equal(iteratedSquare(70), 1);
iteratedSquare(100)
は1
を返す必要があります。
assert.equal(iteratedSquare(100), 1);
--seed--
--seed-contents--
function iteratedSquare(n) {
}
--solutions--
function iteratedSquare(n) {
var total;
while (n != 89 && n != 1) {
total = 0;
while (n > 0) {
total += Math.pow(n % 10, 2);
n = Math.floor(n/10);
}
n = total;
}
return n;
}