Buenas! En esta oportunidad tengo una duda sobre los enteros con ceros al inicio
El caso es que tengo que decodificar una etiqueta compuesta con numero binarios, pero cuando el código empieza por cero no me los toma en cuenta sino hasta el primer 1... como hago para que tome en cuenta los ceros iniciales?
Gracias!
En vez de tomarlo como un entero, puedes tomarlo como una cadena de caracteres.
Me explicare mejor a ver! imagina que tengo un código de 6 números binarios donde los primeros 3 son para identificar a la persona y los últimos 3 para identificar el lugar... 000 es Juan y 001 es Pedro... 000 es casa y 001 es colegio... previamente generado el código lo tengo que decodificar! entonces al pedir el código generado ej. 000001 el programa me tiene que decir Persona Juan Lugar Colegio!
Entonces al declararlo como string podre separar los números? de forma tal que los pueda comparar con los lugares y las personas?
Cita de: cesarjgrd.18 en 6 Noviembre 2011, 18:49 PM
Buenas! En esta oportunidad tengo una duda sobre los enteros con ceros al inicio
El caso es que tengo que decodificar una etiqueta compuesta con numero binarios, pero cuando el código empieza por cero no me los toma en cuenta sino hasta el primer 1... como hago para que tome en cuenta los ceros iniciales?
Gracias!
cuanta los numeros y has una diferenciacion de longitudes asi determinas enq ue posicion esta ese 1
tambien puedes ir almacenando cada numero de esta manera.
Supongamos que tu etiqueta sond e 32 numeros (0 y 1)
entonces:
supongamos este numero.
100010000100001001010110101100
como ves no son 32 numeros los 0 mas significativos no se escriben pero como empiesas tu de la izquierda a la derecha harias algo asi:
entero iCode = 0
mientras no lleguemos al final
iCode = (iCode << 1) | (getBit() mascara con bit 1); // Dezplazmos los bits de iCode a la izquierda y hacemos una operacion OR es decir:
es decir obtienes
100010000100001001010110101100
y lo agregas desplazando los anteriores bits a la izquierda. (<<=)
es decir:
leyendo: 100010000100001001010110101100
INT | en Bits
iCode = 0000000000000000000000000000000
iCode <<= iCode | getBit();
iCode = 0000000000000000000000000000001
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000000010
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000000100
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000001000
...
iCode <<= iCode | getBit();
iCode = 00100010000100001001010110101100
Termino...
como ves se hace un while()...
int iCode = 0;
while(!getEndBit()) {
iCode = (iCode << 1) | (getBit() & 0x1);
}
Dulces Lunas!¡.
Cita de: BlackZeroX (Astaroth) en 7 Noviembre 2011, 00:40 AM
cuanta los numeros y has una diferenciacion de longitudes asi determinas enq ue posicion esta ese 1
tambien puedes ir almacenando cada numero de esta manera.
Supongamos que tu etiqueta sond e 32 numeros (0 y 1)
entonces:
supongamos este numero.
100010000100001001010110101100
como ves no son 32 numeros los 0 mas significativos no se escriben pero como empiesas tu de la izquierda a la derecha harias algo asi:
entero iCode = 0
mientras no lleguemos al final
iCode <<= iCode | getBit(); // Dezplazmos los bits de iCode a la izquierda y hacemos una operacion OR es decir:
es decir obtienes
100010000100001001010110101100
y lo agregas desplazando los anteriores bits a la izquierda. (<<=)
es decir:
leyendo: 100010000100001001010110101100
INT | en Bits
iCode = 0000000000000000000000000000000
iCode <<= iCode | getBit();
iCode = 0000000000000000000000000000001
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000000010
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000000100
iCode <<= iCode | getBit();
iCode = 00000000000000000000000000001000
...
iCode <<= iCode | getBit();
iCode = 00100010000100001001010110101100
Termino...
como ves se hace un while()...
int iCode = 0;
while(!getEndBit()) {
iCode <<= iCode | getBit();
}
Dulces Lunas!¡.
Hola BlackZeroX.. Gracias por esa! Pero debo admitir que no entendí nada! Se que lo explicaste como para tontos pero aun asi no lo entendi! Si puedes echarme una mano gracias!