96 lines
1.8 KiB
Markdown
96 lines
1.8 KiB
Markdown
![]() |
---
|
||
|
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;
|
||
|
}
|
||
|
```
|