Operacion Suma (Vectores) !Duda!

Iniciado por Fire544, 11 Julio 2012, 19:25 PM

0 Miembros y 1 Visitante están viendo este tema.

xiruko

Citarpero todavia la operacion que me pasas no resuelve la problematica, a ver si sumas un vector todo sale bien, pero si intentas simular la logistica de una calculadora se te rompe la caveza xDDD !!

explicame eso de la logistica de una calculadora porque no le veo la gracia.

si como has dicho he entendido el problema que tienes, entonces lo que te he dicho SI lo resuelve. lo que no hare sera darte el codigo, llevo 1 hora y media con esto y por la actitud que tienes creo que ya ha sido suficiente.

relee la explicacion que te he hecho arriba y una vez lo entiendas el codigo lo sacaras en 5 minutos. si tambien operas con numeros reales con decimales entonces tendras que cambiar algo, pero deberias poder sacarlo si, repito una vez mas, entiendes lo que te he explicado.

un saludo y suerte

Fire544

Esta bien implementare otro metodo, luego posteo lo implementado, gracias Xiruko !!
"Si enseñas a pezcar a un niño lo ayudas para toda la vida, si pezcas para alimentarlo lo ayudas por un momento".

flacc

concuerdo con xiruko aunque antes de empezar a concatenar los números como se diría si fueran caracteres tienes que conocer primero por cuantos dígitos tiene cada número para saber a cuanto debes elevar el siguiente 10 que le multipliques... saludos

dato000

Pues porque no pruebas primero en terminal??? luego tratas de implementar en gui, ya que la función scanf deberia funcionar, pero tu dices que no, así que en vez de eventos como tu dices no te funciona (teniendo en cuenta que pues C++ no trabajar programación orientada a objetos sino programación estructurada, esto es, básicamente memoria y punteros).

Pues la logica de elevar las potencias cada cifra aunque sean cifras de más de 1 digito en cada posición se ve que es muy practica, en mi opinión funcionaria bastante bien.

Podrias indicar mejor cuales son los problemas que tienes que no terminamos (o pues al menos yo que acabo de llegar) de comprender el problema??



Fire544

#14
Buenas !! No mira dato000: con un scanf() a nivel consola, funciona correctamente, porque los valores no se le asignan a la variable  hasta que no se pulse un enter o no encuentre un \n; pero en mi caso el problema es el siguiente.

Como ya dije:

scanf("%i", &var1);
scanf("%i", &var2);
suma = var1 + var2;


aqui no hay error alguno y todo marcha perfecto, pero cuando trabajo con eventos es diferente mira esto.

si evento==1
entonces
vector[i]=1;
fin si

si evento==2
entonces
vector[i]=2;
fin si


si te fijas aqui los valores son almacenados instantaneamente o sea no espera un \n o un enter, y aqui se me complica, lo que quiero es una idea de como hacerlo, he intentado ** y char * uff que lio!!

La suma no es la esperada, entonces estoy intentando la manera de buscarle la quinta pata al gato, uff que complicado se ha puesto esto eeeh !!
"Si enseñas a pezcar a un niño lo ayudas para toda la vida, si pezcas para alimentarlo lo ayudas por un momento".

BlackZeroX

Cita de: Fire544 en 11 Julio 2012, 19:25 PM

vector_1[1]=5 + vector_2[1]=65 esto seria igual a 70, y a si sucecivamente, no quiero esto lo que quiero es:


   5   978 6   4   9
+ 65 9    12 66 45
______________
665105294



No entiendo la forma en la que los sumaste... puedes explicar el método paso a paso?... de lo contrario sera imposible ayudarte.

Dulces Lunas!¡.
The Dark Shadow is my passion.

Fire544

BlackZeroX (Astaroth): Fijate intenta sumar esto--> 54 8 6 + 25 90 8 = 31394, ahora intenta implementarlo vector[3]={54,8,6} + vector2[3]={25,90,8} se supondria que esto seria igual a 31394 pero no es asi ya implementado, la suma de los vectores si sumamos de derecha a izquierda daria  791614 si te fijas el valor resultante en la suma de los vectores es incorrecto. Ahora mi pregunta es Como hago para obtener los valores esperados (correctos) ?

Gracias BlackZeroX (Astaroth) !!  :rolleyes:
"Si enseñas a pezcar a un niño lo ayudas para toda la vida, si pezcas para alimentarlo lo ayudas por un momento".

BlackZeroX

aaaaa ya entendí... es simple... dame unos minutos...

Dulces Lunas!¡.

The Dark Shadow is my passion.

Fire544

Cita de: xiruko en 11 Julio 2012, 20:01 PM
imagina que tu tienes el numero en base decimal 123 escrito como un vector de la siguiente manera: vector=[1,2,3]

si quieres pasar del vector a un numero normal, lo que tienes que hacer es multiplicar cada termino del vector por 10 (ya que esta en base decimal) elevado a la posicion que ocupa ese termino en el vector.

en este caso: numero= 1*10^2 + 2*10^1 + 3*10^0 = 100+20+3 = 123

no se explicarme mejor, pero es el mismo sistema que se usa para pasar un numero en base binaria a uno decimal. en este caso, al ser base binaria, en vez de 10 se usa el 2 eleveado a la posicion que ocupe el digito. por ejemplo:

1010 en binario: 1*2^3 + 0*2^2 + 1*2^1 + 0*2^0 = 8+2 = 10 en decimal

edito: solo para decir que es que directamente el sistema numerico es asi. en un numero cualquiera, por ejemplo el 123, el 3 ocupa la posicion de las unidades (del 0 al 9), el 2 el de las decenas (del 0*10 al 9*10), y el 1 el de las centenas (del 0*10^2 al 9*10^2). asi que es esto, pero aplicado a un numero mayor como es tu caso. espero que me haya explicado, un saludo

Si como dices, se puede lograr almacenar dichos valores en los int pero cuando hago esto me petea un resultado no esperado o sea no es el correcto, todavia no va lo que quiero xDD Y me entiendes perfectamente pero no va tu solucion !! Gracias Xiruko !!  ;-)
"Si enseñas a pezcar a un niño lo ayudas para toda la vida, si pezcas para alimentarlo lo ayudas por un momento".

BlackZeroX

#19
.
Intenta con esto...

Código (cpp) [Seleccionar]


#include <iostream>
#include <cstdio>

using namespace std;

inline int lenNum(unsigned int num) {
   char buff[20];
   return sprintf(buff, "%d", num);
}

inline unsigned long long joinVector(unsigned int *vector, size_t size) {
   register int mul = 1;
   register unsigned long long ret = 0;
   while(size--) {
       ret += (vector[size] * mul);
       if (size)
           for (register unsigned int i = 1, ln = lenNum(vector[size]); i <= ln; i++)
               mul *= 10;
   }
   return ret;
}

int main() {
   unsigned int vector1[5] = {5, 978, 6, 4, 9}, vector2[5] = {65, 9, 12, 66, 45};
   cout << joinVector(vector1, 5) + joinVector(vector2, 5) << endl;
   cin.get();
   return 0;
}



  005978649
+ 659126645
______________
665105294


Dulces Lunas!¡.
The Dark Shadow is my passion.