Algoritmo de cifrado César en Ruby

Publicado por parzibyte en

Algoritmo de cifrado César en Ruby

Anteriormente vimos el cifrado César en C y el cifrado César en Python. No explicaré detalladamente cómo funciona el algoritmo pues a ello ya le dediqué otro post.

Lo que nos reúne aquí hoy es la implementación del algoritmo de “cifrado” César en el lenguaje de programación Ruby.

Algoritmo de cifrado César en Ruby

Algoritmo de cifrado César en Ruby

Al final vamos a crear una función que cifra y descifra según el cifrado de César, con un número de rotaciones definido por nosotros.

Función de cifrado césar en Ruby

Ya lo dije arriba pero lo digo de nuevo, aquí no explicaré el algoritmo, solamente pondré la función y cómo es que cada cosa se resuelve usando los métodos del lenguaje.

Dejo el código aquí y lo explico más abajo:

Hasta arriba definimos algunas variables globales que servirán de ayudantes; son el alfabeto y los valores del código ASCII en donde inicia la letra A mayúscula y minúscula.

Recorremos toda la cadena carácter por carácter y en cada iteración vemos si no es una letra; en caso de que no sea una letra, dejamos todo intacto.

En caso de que sí sea una letra entonces vemos si es mayúscula o minúscula y a partir de ello obtenemos el valor después de haber sido rotado. Más tarde tomamos el valor que esté en esa posición según el alfabeto a usar.

Me gusta mucho que la función para el cifrado César es “genérica” porque sirve para codificar y decodificar, ya que acepta un tercer parámetro que es 1 o -1; el cual indica el orden de rotación.

Más sobre la función

En primer lugar recibe la cadena, en segundo el número de rotaciones y en tercero el orden de rotación. Si es hacia la derecha es 1, y si es a la izquierda entonces es 2.

Devuelve una cadena la cual es el mensaje cifrado con las rotaciones indicadas.

Por cierto, para probar si es una letra o no, se utilizó una expresión regular; porque Ruby no provee un método como el isalpha del querido C.

Probar cifrado César hecho en Ruby

Si quieres, descarga el ejemplo, instala Ruby y ejecuta el comando ruby main.rb. También puedes probar el ejemplo en línea:


parzibyte

He trabajado por más de 4 años en el desarrollo de software con experiencia en Java, PHP, JavaScript, HTML, Node.JS, Python, Android y Go. También he trabajado con bases de datos SQL como MySQL y SQLite, así como con bases de datos NoSQL usando MongoDB.Soy bueno utilizando algunos frameworks y herramientas como Firebase, jQuery, AngularJS, VueJS, CodeIgniter, Laravel, BulmaCSS, Bootstrap y Electron.Otros términos que conozco son: Arduino, GraphQL, API's, REST, AJAX, PouchDB, CouchDB, Experiencia de usuario, buenas prácticas de programación, Webpack, NPM, Administración de servidores y programación de scriptsLa plataforma en la que tengo más experiencia es la web, pero en mis ratos libres realizo unos pequeños ejercicios en C# y C.Estoy aquí para ayudarte a resolver tus problemas de programación y depuración :-)

1 Comment

Algoritmo de cifrado ROT13 en Ruby - Parzibyte's blog · febrero 16, 2019 a las 5:01 am

[…] algoritmo ROT 13 es una variante del cifrado César (cuya implementación en Ruby ya vimos) en donde el número de rotaciones es 13; la mitad de la cantidad de letras que existen en el […]

Deja un comentario

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

This site uses Akismet to reduce spam. Learn how your comment data is processed.

A %d blogueros les gusta esto: