164 lines
8.9 KiB
Markdown
164 lines
8.9 KiB
Markdown
|
---
|
||
|
title: Binary Agents
|
||
|
localeTitle: Agentes binarios
|
||
|
---
|
||
|
![](//discourse-user-assets.s3.amazonaws.com/original/2X/7/70cf3cc5462f69c2f770ad42d0f24f240a8d8f13.jpg)
|
||
|
|
||
|
![:triangular_flag_on_post:](https://forum.freecodecamp.com/images/emoji/emoji_one/triangular_flag_on_post.png?v=3 ": triangular_flag_on_post:") Recuerda usar **`Read-Search-Ask`** si te atascas. Tratar de emparejar el programa ![:busts_in_silhouette:](https://forum.freecodecamp.com/images/emoji/emoji_one/busts_in_silhouette.png?v=3 ": busts_in_silhouette:") y escribe tu propio código ![:pencil:](https://forum.freecodecamp.com/images/emoji/emoji_one/pencil.png?v=3 ":lápiz:")
|
||
|
|
||
|
## Explicación del problema:
|
||
|
|
||
|
Este problema es muy sencillo, obtendrá una cadena que representará una oración en código binario y deberá traducirla en palabras. No hay una forma directa de hacer esto, por lo que tendrá que traducir dos veces.
|
||
|
|
||
|
### Enlaces relevantes
|
||
|
|
||
|
* [String.prototype.charCodeAt](http://forum.freecodecamp.com/t/javascript-string-prototype-charcodeat/15933)
|
||
|
* String.fromCharCode
|
||
|
|
||
|
## ![:speech_balloon:](https://forum.freecodecamp.com/images/emoji/emoji_one/speech_balloon.png?v=3 ": speech_balloon:") Sugerencia: 1
|
||
|
|
||
|
Primero debe convertir de **binario** a **decimal** antes de convertir esos valores en caracteres.
|
||
|
|
||
|
> _intenta resolver el problema ahora_
|
||
|
|
||
|
## ![:speech_balloon:](https://forum.freecodecamp.com/images/emoji/emoji_one/speech_balloon.png?v=3 ": speech_balloon:") Sugerencia: 2
|
||
|
|
||
|
Las cosas son más fáciles cuando se enfoca en partes más pequeñas, divida la entrada para enfocar una letra a la vez.
|
||
|
|
||
|
> _intenta resolver el problema ahora_
|
||
|
|
||
|
## ![:speech_balloon:](https://forum.freecodecamp.com/images/emoji/emoji_one/speech_balloon.png?v=3 ": speech_balloon:") Sugerencia: 3
|
||
|
|
||
|
Asegúrate de que cada vez que transcodifiques un carácter de binario a decimal, restablecerás la variable que utilizaste para mantener el seguimiento de los caracteres. Tampoco olvides volver a convertir todo en una sola cuerda.
|
||
|
|
||
|
> _intenta resolver el problema ahora_
|
||
|
|
||
|
## ¡Alerta de spoiler!
|
||
|
|
||
|
![señal de advertencia](//discourse-user-assets.s3.amazonaws.com/original/2X/2/2d6c412a50797771301e7ceabd554cef4edcd74d.gif)
|
||
|
|
||
|
**¡Solución por delante!**
|
||
|
|
||
|
## ![:beginner:](https://forum.freecodecamp.com/images/emoji/emoji_one/beginner.png?v=3 ":principiante:") Solución de código básico:
|
||
|
|
||
|
```javascript
|
||
|
function binaryAgent(str) {
|
||
|
biString = str.split(' ');
|
||
|
uniString = [];
|
||
|
|
||
|
/*using the radix (or base) parameter in parseInt, we can convert the binary
|
||
|
number to a decimal number while simultaneously converting to a char*/
|
||
|
|
||
|
for(i=0;i < biString.length;i++){
|
||
|
uniString.push(String.fromCharCode(parseInt(biString[i], 2)));
|
||
|
}
|
||
|
|
||
|
// we then simply join the string
|
||
|
return uniString.join('');
|
||
|
}
|
||
|
|
||
|
// test here
|
||
|
binaryAgent("01000001 01110010 01100101 01101110 00100111 01110100 00100000 01100010 01101111 01101110 01100110 01101001 01110010 01100101 01110011 00100000 01100110 01110101 01101110 00100001 00111111");
|
||
|
```
|
||
|
|
||
|
![:rocket:](https://forum.freecodecamp.com/images/emoji/emoji_one/rocket.png?v=3 ":cohete:") [Ejecutar código](https://repl.it/CLnm/0)
|
||
|
|
||
|
# Explicación del código:
|
||
|
|
||
|
* Separe la cadena en una matriz de cadenas separadas por espacios en blanco.
|
||
|
* Cree algunas variables que serán necesarias en el camino, los nombres se explican por sí mismos en su mayor parte.
|
||
|
* Iterar a través de cada cadena binaria en la nueva matriz.
|
||
|
* Convierta a decimal usando parseInt ( _binario_ , 2) (con el segundo parámetro que indicamos en qué base están nuestros números actualmente)
|
||
|
* Al final, devolvemos el mensaje convertido.
|
||
|
|
||
|
## Enlaces relevantes
|
||
|
|
||
|
* [String.prototype.split](http://forum.freecodecamp.com/t/javascript-string-prototype-split/15944)
|
||
|
* [parseInt](http://forum.freecodecamp.com/t/javascript-parseint/14686)
|
||
|
|
||
|
## ![:sunflower:](https://forum.freecodecamp.com/images/emoji/emoji_one/sunflower.png?v=3 ":girasol:") Solución de código intermedio:
|
||
|
|
||
|
```javascript
|
||
|
function binaryAgent(str) {
|
||
|
// Separate the binary code by space.
|
||
|
str = str.split(' ');
|
||
|
var power;
|
||
|
var decValue = 0;
|
||
|
var sentence = '';
|
||
|
|
||
|
// Check each binary number from the array.
|
||
|
for (var s = 0; s < str.length; s++) {
|
||
|
// Check each bit from binary number
|
||
|
for (var t = 0; t < str[s].length; t++) {
|
||
|
// This only takes into consideration the active ones.
|
||
|
if (str[s][t] == 1) {
|
||
|
// This is quivalent to 2 ** position
|
||
|
power = Math.pow(2, +str[s].length - t - 1);
|
||
|
decValue += power;
|
||
|
|
||
|
// Record the decimal value by adding the number to the previous one.
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// After the binary number is converted to decimal, convert it to string and store
|
||
|
sentence += (String.fromCharCode(decValue));
|
||
|
|
||
|
// Reset decimal value for next binary number.
|
||
|
decValue = 0;
|
||
|
}
|
||
|
|
||
|
return sentence;
|
||
|
}
|
||
|
|
||
|
// test here
|
||
|
binaryAgent("01000001 01110010 01100101 01101110 00100111 01110100 00100000 01100010 01101111 01101110 01100110 01101001 01110010 01100101 01110011 00100000 01100110 01110101 01101110 00100001 00111111");
|
||
|
```
|
||
|
|
||
|
![:rocket:](https://forum.freecodecamp.com/images/emoji/emoji_one/rocket.png?v=3 ":cohete:") [Ejecutar código](https://repl.it/CLno/0)
|
||
|
|
||
|
# Explicación del Código
|
||
|
|
||
|
* Para cada una de estas cadenas binarias, compruebe las unas e ignore los ceros.
|
||
|
* Para aquellos que son uno o activo, luego conviértalos a decimales, esto tiene en cuenta la posición y la potencia correcta a la que se debe aumentar.
|
||
|
* Almacene la potencia en la variable de **potencia** agregándola a cualquiera de las anteriores en la variable **decValue** . Esta variable agregará y agregará las potencias de las activas hasta el final del bucle y luego devolverá el número decimal.
|
||
|
* Convierta el último decimal fuera del bucle interno y luego conviértalo a ASCII y guárdelo en una **oración** junto con cualquier otra cadena de texto ya convertida y almacenada.
|
||
|
* Restablezca la variable **decValue** para evitar obtener decimales erróneos antes de continuar hacia el bucle externo.
|
||
|
|
||
|
## Enlaces relevantes
|
||
|
|
||
|
* [Math.pow](http://forum.freecodecamp.com/t/javascript-math-pow/14685)
|
||
|
* Longitud de la cuerda
|
||
|
* [Enlace Título 3](http://example.com)
|
||
|
|
||
|
## ![:rotating_light:](https://forum.freecodecamp.com/images/emoji/emoji_one/rotating_light.png?v=3 ": rotando luz:") Solución avanzada de código:
|
||
|
|
||
|
```javascript
|
||
|
function binaryAgent(str) {
|
||
|
return String.fromCharCode(...str.split(" ").map(function(char){ return parseInt(char, 2); }));
|
||
|
}
|
||
|
|
||
|
// test here
|
||
|
binaryAgent("01000001 01110010 01100101 01101110 00100111 01110100 00100000 01100010 01101111 01101110 01100110 01101001 01110010 01100101 01110011 00100000 01100110 01110101 01101110 00100001 00111111");
|
||
|
```
|
||
|
|
||
|
![:rocket:](https://forum.freecodecamp.com/images/emoji/emoji_one/rocket.png?v=3 ":cohete:") [Ejecutar código](https://repl.it/CLnp/0)
|
||
|
|
||
|
# Explicación del Código
|
||
|
|
||
|
* Primero usamos `split()` para poder trabajar en cada personaje como un elemento de Array
|
||
|
* Luego use `map()` para procesar cada elemento de binario a decimal usando `pareseInt()`
|
||
|
* Por último, podemos usar `String.fromCharCode()` para convertir cada número ASCII en el carácter correspondiente
|
||
|
* Sin embargo, `fromCharCode()` espera una serie de números en lugar de un Array. Podemos usar ES6 Spread Operator para pasar una matriz de números como números individuales. Vea aqui para mas informacion; [Operador de propagación](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Spread_operator)
|
||
|
|
||
|
## Enlaces relevantes
|
||
|
|
||
|
* [Array.prototype.map](http://forum.freecodecamp.com/t/javascript-array-prototype-map/14294)
|
||
|
|
||
|
## ![:clipboard:](https://forum.freecodecamp.com/images/emoji/emoji_one/clipboard.png?v=3 ":portapapeles:") NOTAS PARA LAS CONTRIBUCIONES:
|
||
|
|
||
|
* ![:warning:](https://forum.freecodecamp.com/images/emoji/emoji_one/warning.png?v=3 ":advertencia:") **NO** agregue soluciones que sean similares a las soluciones existentes. Si cree que es **_similar pero mejor_** , intente fusionar (o reemplazar) la solución similar existente.
|
||
|
* Agregue una explicación de su solución.
|
||
|
* Categorice la solución en una de las siguientes categorías: **Básica** , **Intermedia** y **Avanzada** . ![:traffic_light:](https://forum.freecodecamp.com/images/emoji/emoji_one/traffic_light.png?v=3 ":semáforo:")
|
||
|
* Agregue su nombre de usuario solo si ha agregado algún **contenido principal relevante** . ( ![:warning:](https://forum.freecodecamp.com/images/emoji/emoji_one/warning.png?v=3 ":advertencia:") **_NO_** _elimine ningún nombre de usuario existente_ )
|
||
|
|
||
|
> Ver ![:point_right:](https://forum.freecodecamp.com/images/emoji/emoji_one/point_right.png?v=3 ": point_right:") [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) para referencia.
|