--- id: 5900f36f1000cf542c50fe82 title: '問題 3: 最大素因数' challengeType: 5 forumTopicId: 301952 dashedName: problem-3-largest-prime-factor --- # --description-- 13195 の素因数は 5, 7, 13, 29 です。 与えられた `number` の最大素因数を求めなさい。 # --hints-- `largestPrimeFactor(2)` は数値を返す必要があります。 ```js assert(typeof largestPrimeFactor(2) === 'number'); ``` `largestPrimeFactor(2)` は 2 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(2), 2); ``` `largestPrimeFactor(3)` は 3 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(3), 3); ``` `largestPrimeFactor(5)` は 5 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(5), 5); ``` `largestPrimeFactor(7)` は 7 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(7), 7); ``` `largestPrimeFactor(8)` は 2 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(8), 2); ``` `largestPrimeFactor(13195)` は 29 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(13195), 29); ``` `largestPrimeFactor(600851475143)` は 6857 を返す必要があります。 ```js assert.strictEqual(largestPrimeFactor(600851475143), 6857); ``` # --seed-- ## --seed-contents-- ```js function largestPrimeFactor(number) { return true; } largestPrimeFactor(13195); ``` # --solutions-- ```js const largestPrimeFactor = (number) => { let largestFactor = number; for (let i = 2; i <= Math.sqrt(largestFactor); i++) { if (!(largestFactor % i)) { let factor = largestFactor / i; let candidate = largestPrimeFactor(factor); return i > candidate ? i : candidate; } } return largestFactor; } ```