freeCodeCamp/curriculum/challenges/japanese/10-coding-interview-prep/project-euler/problem-40-champernownes-co...

1.7 KiB
Raw Blame History

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;
}