Vamos a programar #56 - Los números de Munchhausen (ver. Javascript)
Hola de nuevo a todos, el día de hoy vamos a continuar con la prueba de la conjetura de los números de Munchhausen.
En el post anterior vimos cuales son las reglas, por lo que ahora pasaremos directamente al código javscript para ver las diferencias entre la versión de C# y esta.
El código anterior solo consta de tres funcione en esta ocasión en la función "NumberToDigits()" al convertir el número de entrada a los dígitos que lo forman, directamente hace la resta de 48 para poder usar el número directamente. Para poder recuperar los valores de cada control, hacemos uso de la función "document.getElementById".
Cómo de costumbre, el código lo dejo en mi dropbox para que lo pruebes, al ser el mismo "concepto" que la versión de C#, no requiere una explicación mayor. La semana que viene, veremos la versión para android.
Los leo luego.
En el post anterior vimos cuales son las reglas, por lo que ahora pasaremos directamente al código javscript para ver las diferencias entre la versión de C# y esta.
El código.
El código en javascript para probar los números de Munchhausen es el siguiente:
<html> <head> <style type="text/css"> .h1M { font-size: 16px; } .formVigenere{ font: 95% Arial, Helvetica, sans-serif; max-width: 400px; margin: 10px auto; padding: 16px; background: #F9F9F9; } .textareaM { width: 100%; height: 150px; padding: 2px 5px; box-sizing: border-box; border: 2px solid #999; border-radius: 4px; resize: none; -webkit-transition-duration: 0.4s; /* Safari */ transition-duration: 0.4s; } .textareaM:focus { width: 100%; height: 150px; padding: 2px 5px; box-sizing: border-box; border: 2px solid #00BB00; border-radius: 4px; resize: none; } .TextM { width: 100%; box-sizing: border-box; border: 2px solid #999; border-radius: 4px; } .ButtonM { width: 100%; background-color: #009900; border: none; color: white; padding: 15px 32px; text-align: center; text-decoration: none; display: inline-block; -webkit-transition-duration: 0.4s; /* Safari */ transition-duration: 0.4s; } .ButtonM:hover { width: 100%; background-color: #4CAF50; border: none; color: white; padding: 15px 32px; text-align: center; text-decoration: none; display: inline-block; } </style> <script type="text/javascript"> function NumberToDigits(Number){ var Out = []; for(var i = 0; i < Number.length; i++){ var CodeChar = Number.charCodeAt(i); Out.push(CodeChar - 48); } return Out; } function IsMunchhausen(Number){ var Result = 0; var Digits = NumberToDigits(Number); for(var i = 0; i < Digits.length; i++){ Result += Math.pow(Digits[i], Digits[i]); } if (Number == Result.toString()){ return true; } else{ return false; } } function TestNumbers(){ document.getElementById('Result').value = ""; BeginNumber = document.getElementById('MinNumber').value; EndNumber = document.getElementById('MaxNumber').value; SHowAll = document.getElementById('ShowAll').checked; for (var i = BeginNumber; i <= EndNumber; i++){ if (IsMunchhausen(i.toString())) document.getElementById('Result').value += "La conjetura se cumple para el número " + i + "\n"; else if (SHowAll) document.getElementById('Result').value += "El número " + i + " no cumple la conjetura\n"; } } </script> </head> <body> Utilidad para probar la conjetura de Munchhausen usando javascript. <form class="formVigenere"> <span class="h1M">Numero de donde empezar:</span> <br /> <input class="TextM" id="MinNumber" value = "1" type="text"></input><br /> <span class="h1M">Numero hasta donde llegar</span><br /><br/> <input class="TextM" id="MaxNumber" value = "5000" type="text" /><br /> <br /> <input class="ButtonM" id="Calcula" onclick="TestNumbers()" type="button" value="Calcular" /><br /> <br /> <input type="checkbox" id = "ShowAll" value="Bike">Mostrar Todo<br><br> <span class="h1M">Resultado</span><br/> <textarea class="textareaM" id="Result" rows="5"></textarea><br/><br/> </form> </body> <html>
El código anterior solo consta de tres funcione en esta ocasión en la función "NumberToDigits()" al convertir el número de entrada a los dígitos que lo forman, directamente hace la resta de 48 para poder usar el número directamente. Para poder recuperar los valores de cada control, hacemos uso de la función "document.getElementById".
Cómo de costumbre, el código lo dejo en mi dropbox para que lo pruebes, al ser el mismo "concepto" que la versión de C#, no requiere una explicación mayor. La semana que viene, veremos la versión para android.
Los leo luego.
No hay comentarios.