![]() |
Cómo convertir un número binario al tipo Real
Hola !! Que tal... cuanto tiempo sin pasarme =D eso es bueno, es porque progreso sin problems. Tengo una duda para vosotros ;) jejejeje... a ver la suelto... Quisiera un codigo, o bueno saber como a salido ese "codigo" para hacer una conversion de binario a un numero real ^^ Utilizando edits o tabla... me da igual ^^ No se si me explico pero bueno graaaaaacias. PD1: Cambiad el titulo que no sabia cual ponedle. |
Hola :)
Según mi ayuda de Delphi: Cita:
Si recuerdo bien lo que me enseñaron en clase de informática, el valor del número sería f·10^(e-129) (escrito en notación científica). En trucomanía tienes un par de trucos para pasar Integer<->Binario: http://www.q3.nu/trucomania/truco.cgi?122&esp http://www.q3.nu/trucomania/truco.cgi?187&esp Lo que no sé cómo hacer es extraer esos 39 bits (cuarenta tomando el signo) por separado para pasarlos a binario, y después hacerlo con los otros 8 :( ¿Alguien que aporte cómo, o que me corrija si me equivoco? |
Buaaaah a llorar xD yo se hacerlo con cuentas ^^
Mike cambie de blog xD www.lavidaesbella.motime.com xD por si te interesa ^^ Te gusto mi felicitacion? Jjajaja tengo otra pregunta ya de contenido informatico ^^ me he bajado el todo en uno v8... y son 2 dvd de 8 gb cada uno por lo visto. ¿Como lo grabo? Si mi dvd tiene 4,7 GB !!! XD |
Hay DVDs de 8'5 GB e incluso de 17 GB (doble capa, doble cara). Y sí, me llegó la felicitación :) gracias.
|
¿No hay manera de poderlo hacer en DVD normales? Jajajaja.
|
¿Podrías hacerme un favor? He visto los codigo de: http://www.q3.nu/trucomania/truco.cgi?122&esp pero vamos... ni idea de como usarlos porque hay "comandos" que no he estudiado aún. Si podrías hacerme un programa a través de ese codigo y yo lo veo, lo estudio y lo aprendo. =) Uno sencillito. Jajaja
PD: Soy pesado (por eso digo que si estoy en un foro, temblad :p) |
No utliza ningún "comando" extraño, tan sólo es el código de una función recursiva (bueno, hay muchas, distintas formas de hacer lo mismo) a la que se pasas un integer y te devuelve un string que es el número en binario.
Si no entiendes lo que hace exactamente después de examinarla, pues entonces déjala para un futuro. Utiliza algunos operadores un tanto atípicos, al menos para mí (vale, ni yo entiendo el código :o). Y para que no me digan nada por ahí, te digo que en Delphi no hay "comandos", pero sí funciones, métodos, tipos, objetos, eventos, operadores... A todo esto... ¿qué es lo que quieres hacer exactamente? |
Quiero un programa que haga esto, lo necesito locamente para mañana a las 8:30... así que imagínate xD jajaja.
|
¡Será posible! Deberías haber empezado un poco antes, ¿no?
A ver qué te parece esto (no sé si funciona correctamente):
Espero que te sirva (mira a ver si puedes hacerlo tú con un puntero a una matriz, en vez de a una estructura ;)). Salu2. |
Pero.. todo esto donde lo meto? En un button, en el fondo del programa... ¿donde? :S Soy un no-va-to xD con todas sus letras.
|
Cita:
Cita:
Salud OS |
Es que no entiendo nada de lo que hay en el codigo, tenemos un nivel muy bajo, lo ultimo que dimos fue el: if, for y copy
Imagínate. Por cierto... egostar... ¿tu jugabas a habbo? |
Cita:
Cita:
Salud OS |
Mejor lo dejo... no tengo ni idea de que es
VariableString := RealToBin(19.25); Es que en ese juego había un egostar :P por eso me sonaba jujuju. Gracias por la ayuda. |
Cita:
VariableString es una variable de tipo string, a la que se asigna el valor que retorna la función RealToBin (creada por mí) cuando le pasas el parámetro 19'25. RealToBin la puedes poner en varios sitios; te recomiendo en implementation. Ahora tengo que pedir disculpas por un pequeño despiste que he tenido, te he dado la función inversa a la que buscabas :o: Cita:
¿Estás seguro de que el número tiene que ser real? Porque con un entero la cosa queda muy fácil, pero con un real... mucho nivel para alumnos que sólo han visto if, for y copy. Bueno, entonces consideremos el caso binario a entero. En los enlaces que te he puesto al principio hay una función que lo hace, pero vamos a pasar de ella, y vas a hacer tú mismo el método ;). Para empezar, ¿cómo vas a recibir ese número binario? Seguramente lo escribirás en un edit, bueno, eso se espera. Ok. Olvidémonos por un momento de la informática y dime: ¿sabes convertir un número en binario a decimal? Es decir, ¿sabes que 1010101010 es 682? Espero que sí :D: vas recoriendo los dígitos binario, de derecha a izquierda, sumando potencias de base 2. Vale, ahora, ¿cómo aplicar este sistema en tu código Delphi? Veamos: -Recorrer los carácteres de derecha a izquierda: El texto del edit se guarda en su propiedad Text, de tipo string. Si has estudiado ;) sabrás que se pueden acceder a los distintos carácteres de un string como si de una matriz de Char se tratara. Así, para leer el 3er carácter harás:
A diferencia de otros tipos o lenguajes, en Delphi el string comienza en el carácter 1, y no en el 0. Pero, para recorrer de derecha a izquierda, ¿cómo hacerlo? Necesitarás un bucle (por la repetición) y saber cuántos carácteres tienes en el edit. Para lo segundo tienes la función Lenght (mira en la ayuda de Delphi para aprender cómo se usa, aunque es muy muy simple). Así, para recorrer todos los carácteres del edit haremos:
Vale, ahora ya sólo queda calcular el número en sí. Pues con todo lo que sabemos, lo único que falta saber es cómo calcular una potencia; la función Power de la unit math nos lo da. Toma, el código que tanto ansiabas:
Espero que esté lo suficientemente claro. Cualquier función que no sepas para qué sirve, puedes buscarla en la ayuda de Delphi. Y recuerda añadir math a la uses. Salu2. |
Dios! Que pasanda de escribir. Pues sí soy el mismo kbaby con mucho sueño pero bueno xD y con pocas ganas porque estoy estudiando a petrarca a la vez así que imagínate... =) Petrarca, fray luis de leon ... etc
La funcion Length si la he visto, por lo demás.. nothing de nothing xD. Voy a intentar ir captando pasito a pasito , lo que me has escrito. Volveré... xD PD: Nosotros no estudiamos, simplemente vamos viendo "funciones" poco a poco, como te comenté, primero el for, luego if, luego copy... etc etc xD PD2: Lo que quiero es pasar de un nº binario (10101010101010) a un numero normal (real supongo) por ejemplo 69 :P |
Me he atrancado aquí:
const Cadena = 'ABCDEF'; var TercerCaracter: Char; begin TercerCaracter:=Cadena[3]; //TercerCaracter ahora debe valer "C" end; ABCDEF ... supongo que ese código ira en un button... pero como voy a poner en ese button ABCDEF xD PD: Soy... principiante (mas por debajo) PD2: He leído el código completo y e ido transladando todo a lo que yo sé y me atranqué en: If Edit1.Text[n]='1' then //Si el número es un uno Inc(Numero, Power(2, Length(Edit1.Text)-n)); Edit1.Text[n] -> No lo he visto nunca después de text añadir [n] ... T_T |
Cita:
Cita:
Cita:
Dile a tu profesor(a) que os enseñe un poco más de lo básico antes de empezar con nuevas funciones ;) Salu2, y que vaya bien con la literatura :) |
Al fin termine literatura xD Voy a intentar hacer eso de binario a decimal de esta forma.
Guardare la longitud del binario en una variable cantidad Hare un for para que se repita tantas veces como esa cantidad
|
Volvamos a ver mi código:
Lenght(Edit1.Text) es lo que tú quieres llamar cantidad, pero si así te aclaras mejor, pues entonces hazlo :) If Edit1.Text[n]='1' then significa "si el carácter n es uno entonces...". Así es como discrimino al cero. La función Inc incrementa la variable Numero en la cantidad que se le dice en el segundo parámetro. Estas dos líneas hacen lo mismo:
Lo que hago es incrementarlo la potencia de dos, teniendo en cuenta que el exponente es el orden del carácter leído, comenzando por la derecha y desde cero. Si te fijas, cantidad - n ya hace esto (al principio vale 0, y al final cantidad - 1) A ver si de esta forma te aclaras más:
¿Mejor así? :) Salu2. |
Hola! Como nadie sabíamos hacerlo nos dijo que no nos explicó que se hacía con el for con downto ... pero bueno mañana tengo la posibilidad de entregarlo. He visto tu código y donde pone lenght ....¿no sería length?
En delphi, puse un edit y un button y metí el code enel button. Y cuando le doy a F9 me señala la linea donde dice Power diciendo de error: Undeclared identifier: 'Power'. Y luego otro error en la misma línea de que falta un ; porque dice Missing Operator semiclon xD Siento ser así de pasado, pero bueno.... es que quiero aprender y quiero aprender mucho más... necesito hacer un proyecto para junio ! Y quiero empezar ya en mi casa. |
He buscado en Delphi help, y me dice que la función Power es:
Power(const Base, Exponent: Extended): Extended; ¿No faltan las palabras en negrita? |
Es obvio que lo ha escrito de memoria, así que es fácil cometer errores.
lenght es uno de mis errores más comunes :D En la misma ayuda, te dice que power está en la unidad Math, por ende, tienes que poner : uses Math; para que compile. Lo del punto y coma, pues lo corrijes y listo ;) Las palabras en negritas, son la declaración de tipos de la función, es decir, te dice que recibe un tipo de dato en coma foltante (Extended), aunque un integer es totalmente compatible con ellos. La palabra "const" viene a decir que esos parámetros no se van a modificar dentro de la función "power". Saludos |
No se donde poner uses Math;
Lo siento... xD mi inexperiencia... es 100% Gracias por la rapidez tio. |
kbaby,
una unidad viene así:
Lee la ayuda kbaby... allí está todo... además si emplearas el buscador de los foros llegarías a hilos en donde se han expuesto estas preguntas. Saludos, |
Lo intento... pero como en esas ayudas viene información demás.. pues me es imposible encontrar la explicación. Necesito un manual que empieze desde cero.
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls, math; Aquí puse lo de math, pero me sigue señalando la linea donde está power.... diciendome tipo incompatible integer y extended y mission operartor semiclon... pd: lo siento... :( |
Missing operator or semicolon te sale seguramente porque te falta un puntocoma.
El otro error es porque has puesto un extended donde va un integer. Desde luego necesitas un manual para empecar desde cero :D, en el FTP del club tenemos La cara oculta de Delphi 4, que va desde cero hasta experto ;) Salu2. |
Recomendadme un libro, que voy a salir a las 17.00 a comprarme un manual. Decidme titulos bueno porfavor. :) Quiero aprenderlo a fondo.
|
Pero... como corrigo esos errores :S yo veo todo con ;
Es que damos muy pocas cosas en informática :S (a veces digo que porque no os venís de profesores... xD) |
Cita:
Si expusieras el código que tienes hecho, con tus correcciones, podríamos saber que haces (o no haces). Si estás dispuesto a comprar libros, Busca "La Biblia de... " de Marcos Cantú. Saludos, |
Cita:
Si no es cosa de ";" será algún operador (como algo:=otracosa;) |
Aquí esta lo que tengo:
Cita:
|
Hola...
Aquí tu código corregido... checa el comentario...
Saludos... |
Madre mía!!! Por esa cosa me sale todo eso... dios muchas gracias, Ahora queda el último error, me sale:
Incompatible types: 'Integer' and 'Extended'. Y me señala la línea: Numero := Numero + Power(2, Cantidad - n); ¿Por qué? PD: Gracias. |
Hola...
El problema está en que Número es una variable de tipo Integer y la función Power devuelve un valor del tipo Extended, entonces, al hacer:
El resultado se convierte automáticamente en Extended y ese valor no lo puedes asignar a la variable Numero, de ahí que te de ese error... Prueba haciendo esto:
Saludos... |
Nunca use lo de Extended
Ahora sale otro error aquí:
Debido a que numero antes era integer... que tengo que poner en lugar de IntToStr. Nunca he estudiado (por ahora) ese tipo de variable. |
Hola...
Bueno si, ahora Numero no es de tipo Integer y es por eso que ya no puedes usar esa función.. Ahora tienes que usar: FloatToStr Saludos... |
Otra duda xD ¿float no era para cuando utilizabas una variable real?
Ya funciona! Muchas gracias a todos (aora vengo voy a ir a la libreria a comprarme eso) No cerreis el post, que ahora os comento cosas del libro y doy mas gracias a todos). |
El tipo Extended es un tipo de datos Real...
Por cierto, en Delphi ya no se usa el tipo de datos Float, se usa Double en su lugar... Saludos... |
Float, Double, Extended, Real, Currency y Comp (y no sé si alguno más) son distintos tipos de datos que sirven para almacenar números reales. La diferencia entre ellos es la cantidad de memoria que ocupan (y por tanto, la precisión que tienen). Aunque me parece que algunos son equivalentes a otros y sólo se mantienen por compatibilidad.
|
| La franja horaria es GMT +2. Ahora son las 20:59:56. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi