2021-06-15 00:49:18 -07:00
---
id: 5eaf48389ee512d4d103684b
2021-09-06 03:52:36 -07:00
title: Números autodescritivos
2021-06-15 00:49:18 -07:00
challengeType: 5
forumTopicId: 385289
dashedName: self-describing-numbers
---
# --description--
2021-09-06 03:52:36 -07:00
Há vários números inteiros chamados de ["autodescritivos" ](https://en.wikipedia.org/wiki/Self-descriptive_number ).
2021-06-15 00:49:18 -07:00
2021-09-06 03:52:36 -07:00
Diz-se que um número inteiro é "autodescritivo" quando ele tem uma propriedade que, quando as posições dos dígitos são rotuladas de 0 a N-1, o algarismo em cada posição é igual ao número de vezes em que o algarismo aparece no número.
2021-06-15 00:49:18 -07:00
2021-09-06 03:52:36 -07:00
Por exemplo, **2020** é um número autodescritivo de quatro dígitos:
2021-06-15 00:49:18 -07:00
< ul >
2021-09-06 03:52:36 -07:00
< li > a posição 0 tem o valor 2 e há dois 0s no número; < / li >
< li > a posição 1 tem valor 0 e o número 1 não é encontrado no número; < / li >
< li > a posição 2 tem o valor 2 e há dois 2s no número; < / li >
< li > a posição 3 tem o valor 0 e o número 3 não é encontrado no número; < / li >
2021-06-15 00:49:18 -07:00
< / ul >
2021-09-06 03:52:36 -07:00
Os números autodescritivos < 100.000.000 são: 1210, 2020, 21200, 3211000, 42101000.
2021-06-15 00:49:18 -07:00
# --instructions--
2021-09-06 03:52:36 -07:00
Escreva uma função que receba um número inteiro positivo como parâmetro. Se ele for autodescritivo, retorne true. Caso contrário, retorne false.
2021-06-15 00:49:18 -07:00
# --hints--
2021-09-06 03:52:36 -07:00
`isSelfDescribing` deve ser uma função.
2021-06-15 00:49:18 -07:00
```js
assert(typeof isSelfDescribing == 'function');
```
2021-09-06 03:52:36 -07:00
`isSelfDescribing()` deve retornar um booleano.
2021-06-15 00:49:18 -07:00
```js
assert(typeof isSelfDescribing(2020) == 'boolean');
```
2021-09-06 03:52:36 -07:00
`isSelfDescribing(2020)` deve retornar `true` .
2021-06-15 00:49:18 -07:00
```js
assert.equal(isSelfDescribing(2020), true);
```
2021-09-06 03:52:36 -07:00
`isSelfDescribing(3021)` deve retornar `false` .
2021-06-15 00:49:18 -07:00
```js
assert.equal(isSelfDescribing(3021), false);
```
2021-09-06 03:52:36 -07:00
`isSelfDescribing(3211000)` deve retornar `true` .
2021-06-15 00:49:18 -07:00
```js
assert.equal(isSelfDescribing(3211000), true);
```
# --seed--
## --seed-contents--
```js
function isSelfDescribing(n) {
}
```
# --solutions--
```js
function isSelfDescribing(n) {
let digits = String(n).split("");
digits = digits.map(function(e) {return parseInt(e)});
let count = digits.map((x) => {return 0})
digits.forEach((d) =>{
if (d >= count.length) {
return false
}
count[d] += 1;
});
if (digits === count) {
return true;
}
if (digits.length != count.length) {
return false;
}
2021-07-09 21:23:54 -07:00
2021-06-15 00:49:18 -07:00
for (let i=0; i< digits.length ; i + + ) {
if (digits[i] !== count[i]) {
return false;
}
}
return true;
}
```