Ejecución de algoritmo - Texto a binario en C

Texto a binario en C – Pequeño traductor

Resumen: mostrar cómo convertir texto (oraciones, palabras, letras) a su representación binaria en C (usando ceros y unos). Es decir, hacer un traductor de texto a binario en ANSI C.

Por ejemplo, convertir Mi nombre es Luis Cabrera Benito en 01001101 01101001 00100000 01101110 01101111 01101101 01100010 01110010 01100101 00100000 01100101 01110011 00100000 01001100 01110101 01101001 01110011 00100000 01000011 01100001 01100010 01110010 01100101 01110010 01100001 00100000 01000010 01100101 01101110 0110100

Convertidor de texto a binario en C

Te aviso de una vez que voy a usar la función itoa y el método para rellenar cadenas; pues itoa no regresará números binarios de 8 dígitos (ya que los ceros a la izquierda no cuentan, pero para el traductor son importantes).

Comencemos…

Nota: si quieres ver el proceso inverso (binario a texto) mira este post.

Obtener y recorrer cadena

Primero debemos obtener el texto que vamos a recorrer, que será una cadena al final. Esta cadena la puedes leer del usuario con fgets o simplemente definirla; yo haré lo segundo:

// El texto que vamos a traducir
char *texto = "Mi nombre es Luis Cabrera Benito";

Ahora recorremos letra por letra y dentro de cada iteración, vamos a convertir el valor del carácter en su representación ASCII o valor ASCII (char a int).

Por ejemplo, el @ se convierte en 64 y así según las equivalencias.

int decimal = 0;
int i = 0;
while (texto[i] != '\0') {
    decimal = (long) texto[i];// Obtener valor ASCII del carácter
    // Magia aquí
    i++;
}

Convertir texto a binario en C

Antes del ciclo, debemos definir una cadena que servirá para guardar el texto en binario de cada carácter; debe ser de al menos 8 dígitos agregando además el carácter nulo:

char cadena[9];

Y dentro del ciclo invocamos a itoa que pondrá el resultado dentro de cadena. Después de eso, rellenamos la cadena con ceros a la izquierda y vamos imprimiendo hasta terminar de recorrer la cadena.

El ciclo while queda así:

while (texto[i] != '\0') {
    decimal = (long) texto[i];// Obtener valor ASCII del carácter
    // Convertir y almacenar el binario en "cadena"
    itoa(decimal, cadena, 2);
    // Diferencia para saber si no mide 8
    int diferencia = 8 - (int) strlen(cadena);
    // Imprimir. El %*.*s es para rellenar la cadena con ceros a la izquierda
    // https://stackoverflow.com/questions/276827/string-padding-in-c/9741091#9741091
    printf("%*.*s%s ", diferencia, diferencia, relleno, cadena);
    i++;
}

Como puedes notar, la conversión a base 2 se hace en la línea 4. Una vez que eso se ha hecho, cadena tiene el número binario, pero la rellenamos con N caracteres (en donde N es la diferencia, línea 6)

Finalmente la imprimimos y así queda completo.

Poniendo todo junto

Así que el código completo del traductor de texto a binario en C queda así:

/**
 * Traductor de texto a binario en ANSI C
 *
 * @author parzibyte
 * @see https://parzibyte.me/blog
 * */
#include <stdio.h>
#include <string.h>

/**
	 * C++ version 0.4 char* style "itoa":
	 * Written by Lukás Chmela
	 * Released under GPLv3.

	 */
char *itoa(int value, char *result, int base) {
    // check that the base if valid
    if (base < 2 || base > 36) {
        *result = '\0';
        return result;
    }

    char *ptr = result, *ptr1 = result, tmp_char;
    int tmp_value;

    do {
        tmp_value = value;
        value /= base;
        *ptr++ = "zyxwvutsrqponmlkjihgfedcba9876543210123456789abcdefghijklmnopqrstuvwxyz"[35 +
                                                                                           (tmp_value - value * base)];
    } while (value);

    // Apply negative sign
    if (tmp_value < 0) *ptr++ = '-';
    *ptr-- = '\0';
    while (ptr1 < ptr) {
        tmp_char = *ptr;
        *ptr-- = *ptr1;
        *ptr1++ = tmp_char;
    }
    return result;
}


int main(void) {
    // El texto que vamos a traducir
    char *texto = "Mi nombre es Luis Cabrera Benito";
    printf("En texto es: %s\n", texto);
    char *relleno = "00000000";
    // El número que irá tomando cada letra
    int decimal = 0;
    char cadena[9];
    int i = 0;
    printf("En binario es: \n");
    while (texto[i] != '\0') {
        decimal = (long) texto[i];// Obtener valor ASCII del carácter
        // Convertir y almacenar el binario en "cadena"
        itoa(decimal, cadena, 2);
        // Diferencia para saber si no mide 8
        int diferencia = 8 - (int) strlen(cadena);
        // Imprimir. El %*.*s es para rellenar la cadena con ceros a la izquierda
        // https://stackoverflow.com/questions/276827/string-padding-in-c/9741091#9741091
        printf("%*.*s%s ", diferencia, diferencia, relleno, cadena);
        i++;
    }
}

Recuerda que la función itoa la defino porque en Linux no está presente. La salida al ejecutarlo al menos con el texto mostrado es:

Ejecución de algoritmo - Texto a binario en C
Ejecución de algoritmo – Texto a binario en C

Si quieres probar que funciona, puedes usar este traductor que programé yo.

Si quieres más sobre C de mi blog haz click aquí.

Actualización: aquí puedes ver cómo convertir binario a texto en ANSI C.

Estoy aquí para ayudarte 🤝💻


Estoy aquí para ayudarte en todo lo que necesites. Si requieres alguna modificación en lo presentado en este post, deseas asistencia con tu tarea, proyecto o precisas desarrollar un software a medida, no dudes en contactarme. Estoy comprometido a brindarte el apoyo necesario para que logres tus objetivos. Mi correo es parzibyte(arroba)gmail.com, estoy como@parzibyte en Telegram o en mi página de contacto

No te pierdas ninguno de mis posts 🚀🔔

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.

4 comentarios en “Texto a binario en C – Pequeño traductor”

    1. Podrías poner el código con ese añadido, de que se pueda ingresar datos en la interfaz del programa, por favor, intento y no me sale.

Dejar un comentario

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *