1.7 KiB
1.7 KiB
id, title, challengeType, forumTopicId, dashedName
id | title | challengeType | forumTopicId | dashedName |
---|---|---|---|---|
5900f3941000cf542c50fea7 | 問題 40: チャンパーノウン定数 | 5 | 302066 | problem-40-champernownes-constant |
--description--
正の整数を連結することで得られる、次のような無理数の小数を考えます。
0.123456789101112131415161718192021...
小数第 12 位が 1 であることが分かります。
dn が小数第 n 位を表すとき、次の式の値を求めなさい。
d1 × d10 × d100 × d1000 × d10000 × d100000 × d1000000
--hints--
champernownesConstant(100)
は数値を返す必要があります。
assert(typeof champernownesConstant(100) === 'number');
champernownesConstant(100)
は 5 を返す必要があります。
assert.strictEqual(champernownesConstant(100), 5);
champernownesConstant(1000)
は 15 を返す必要があります。
assert.strictEqual(champernownesConstant(1000), 15);
champernownesConstant(1000000)
は 210 を返す必要があります。
assert.strictEqual(champernownesConstant(1000000), 210);
--seed--
--seed-contents--
function champernownesConstant(n) {
return true;
}
champernownesConstant(100);
--solutions--
function champernownesConstant(n) {
let fractionalPart = '';
for (let i = 0; fractionalPart.length <= n; i++) {
fractionalPart += i.toString();
}
let product = 1;
for (let i = 0; i < n.toString().length; i++) {
const index = 10 ** i;
product *= parseInt(fractionalPart[index], 10);
}
return product;
}