2021-06-15 07:49:18 +00:00
|
|
|
---
|
|
|
|
id: 5900f3731000cf542c50fe86
|
2021-08-02 14:05:44 +00:00
|
|
|
title: 'Problema 7: 10001º número primo'
|
2021-06-15 07:49:18 +00:00
|
|
|
challengeType: 5
|
|
|
|
forumTopicId: 302182
|
|
|
|
dashedName: problem-7-10001st-prime
|
|
|
|
---
|
|
|
|
|
|
|
|
# --description--
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
Ao listar os primeiros seis números primos: 2, 3, 5, 7, 11 e 13, podemos ver que o sexto número primo é 13.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
Qual é o `n`-ésimo número primo?
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
# --hints--
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(6)` deve retornar um número.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert(typeof nthPrime(6) === 'number');
|
|
|
|
```
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(6)` deve retornar 13.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.strictEqual(nthPrime(6), 13);
|
|
|
|
```
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(10)` deve retornar 29.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.strictEqual(nthPrime(10), 29);
|
|
|
|
```
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(100)` deve retornar 541.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.strictEqual(nthPrime(100), 541);
|
|
|
|
```
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(1000)` deve retornar 7919.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.strictEqual(nthPrime(1000), 7919);
|
|
|
|
```
|
|
|
|
|
2021-08-02 14:05:44 +00:00
|
|
|
`nthPrime(10001)` deve retornar 104743.
|
2021-06-15 07:49:18 +00:00
|
|
|
|
|
|
|
```js
|
|
|
|
assert.strictEqual(nthPrime(10001), 104743);
|
|
|
|
```
|
|
|
|
|
|
|
|
# --seed--
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
```js
|
|
|
|
function nthPrime(n) {
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
nthPrime(10001);
|
|
|
|
```
|
|
|
|
|
|
|
|
# --solutions--
|
|
|
|
|
|
|
|
```js
|
|
|
|
const nthPrime = n => {
|
|
|
|
let pN = 2;
|
|
|
|
let step = 0;
|
|
|
|
while (step < n) {
|
|
|
|
let isPrime = true;
|
|
|
|
let rootN = Math.sqrt(pN);
|
|
|
|
for (let i = 2; i <= rootN; i++) {
|
|
|
|
if (!(pN % i)) {
|
|
|
|
isPrime = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
isPrime ? step++ : '';
|
|
|
|
pN++;
|
|
|
|
}
|
|
|
|
return pN - 1;
|
|
|
|
}
|
|
|
|
```
|