Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - ivancea96

#1541
Programación C/C++ / Re: Duda sobre vectores!
29 Diciembre 2015, 14:40 PM
Dividí el código en 2 partes, ahí las marqué con comentarios (los 2 for).

En la primera, solo sumamos todos los números. Pasaría de:
0 1 1 2
A:
0 0 2 2

En la segunda, movemos todos los números distintos de 0 (no vacíos), a la izquierda (en este caso; derecha si se apilan hacia la derecha).
Quedaría:
2 2 0 0

La segunda parte, acabo de ver, que tiene un error. Aquí al final te pongo el código final.

La segunda parte primero, la más rápida:
"temp" guarda la posición vacía en la que meteremos los números. Empieza por la primera casilla igual a 0. A partir de esa casilla, cuando encontramos un número diferente de 0 (una casilla no-vacía), lo intercambiamos con la posición vacía. por ejemplo, pasaría de:
0 0 2 2  (temp=0, i=2)
A:
2 0 0 2 (temp=1, i=2)

Y vamos a otro ciclo del bucle.


La primera parte, as casi lo mismo, pero al revés. Por cada casilla no-vacía desde la izquierda, buscamos la siguiente no-vacía. Si el número de la siguiente es el mismo (se pueden sumar), los sumamos, y eliminamos uno de ellos (el primero en este caso). Luego, cogemos el siguiente número, y repetimos.
En este código, temp guarda -1 mientras no se encuentra ningún número diferente de 0. Cuando encontramos uno, guardamos su posición en temp. Luego, al encontrar un segundo, comprobamos lo dicho anteriormente. En caso de que no sean iguales, establecemos temp a este último valor, y continuamos. Si son iguales, se suman, y temp lo volvemos a establecer a -1, hasta que encontremos el siguiente valor no-vacío.

Código (cpp) [Seleccionar]
    #include <iostream>
     
    int main(){
    int arr[4] = {0,1,1,2};
    int temp = -1;
     
    for(int i=0; i<4; i++){ // SUMAMOS LOS NÚMEROS IGUALES CONSECUTIVOS
    if(temp!=-1){
    if(arr[temp]==arr[i]){ // Encontrados dos consecutivos iguales
    arr[temp] = 0; // Eliminamos uno
    arr[i] *= 2; // Duplicamos el otro
    temp = -1;
    }else{
    temp = i; // Si no son iguales, cogemos el último
    }
    }else if(arr[i]!=0){
    temp = i;
    }
    }
     
    for(temp=0; temp<4; temp++) // AÑADIDO: Colocamos 'temp' al primer número no-vacío
                if(arr[temp]!=0)
                        break;
        // AÑADIDO: 'i' empieza siendo uno más que 'temp'
    for(int i=temp+1; i<4; i++) // COLOCAMOS TODOS LOS NÚMEROS AL PRINCIPIO
    if(arr[i]!=0){
    arr[temp++] = arr[i];
    arr[i] = 0;
    }
     
    for(int i=0; i<4; i++)
    std::cout << arr[i] << " ";
    }


Espero que lo entiendas así jaja
Si no, dime sin problema
#1542
Foro Libre / Re: ¿Hay alguien ahí fuera?
26 Diciembre 2015, 02:44 AM
Interferencia.
#1543
Has colocado std:.cout o using namespace std; ?
#1544
Es el foro el que te pide a ti un buen argumento para implementarlo. Yo no conozco una razón tal para implementarlo, ni has expuesto ninguna.
#1545
Siendo un foro de esta índole, si crees que algo que se ha dicho es incorrecto, se comenta en un mensaje. Por lo demás, ¿qué hay que valorar?

En StackOverlofw por ejemplo, las valoraciones ayudan a encontrar la respuesta más correcta. Pero aquí el sistema no es ese.
#1546
¿Qué ocurre si el primer while sale por el conducto ordinario? (*str == 0)
Pues que se acabó la cadena y no s eha encontrado el delimitador.
Sin embargo, ignoras esa posibilidad, incrementas str, y te posiciones fuera de la cadena. Desde ahí, todo lo que hagas, puede dar lugar a error y es inesperado para el programador final.

E insisto, para incrementar un puntero, str++. El * sobra.
#1547
Cita de: nonpromisc en 24 Diciembre 2015, 20:15 PM
El while(*str) comprueba que str no sea '\0'.

Pero eso no soluciona ninguno de los problemas.

En la línea *str++;. Incrementas sin comprobar si llegaste a un caracter nulo. No sabes si saliste del bucle por caracter nulo, o si saliste por haber encontrado el delimitador.
Y a todo esto, no necesita el *str++.
#1548
Ten en cuenta que existe la función strtok.

A parte, en esa función das por hecho que el segundo y tercer argumento estarán llenos de caracteres nulos.
Además, utilizas como límite uint8_t. ¿Por qué? Son char*, no uint8_t*, tenlo en cuenta.
Luego, ¿qué ocurre si no encuentra el delimitador? Sin comprobar nada, incrementas el puntero, y empiezas a leer memoria que tal vez no te pertenezca.

Hicise la función pensando en el mejor de los casos. Piensa también en el peor de los casos (en cualqueira de ellos).

Las funciones de la librería estándar hacen exactamente lo que dicen. ¿Qué ocurriría si metieras esa función en la librería?

Está bien que quieras compartir tu librería, pero en ese caso, te recomendaría que publicases en, por ejemplo, github.
#1549
Programación C/C++ / Re: Duda sobre vectores!
24 Diciembre 2015, 17:21 PM
Siendo 0 un vacío, supon una fila o columna así:
0 1 1 2
Si hay que apilarlos hacia la izquierda, harías algo como:
Código (cpp) [Seleccionar]
#include <iostream>

int main(){
int arr[4] = {0,1,1,2};
int temp = -1;

for(int i=0; i<4; i++){ // SUMAMOS LOS NÚMEROS IGUALES CONSECUTIVOS
if(temp!=-1){
if(arr[temp]==arr[i]){ // Encontrados dos consecutivos iguales
arr[temp] = 0; // Eliminamos uno
arr[i] *= 2; // Duplicamos el otro
temp = -1;
}else{
temp = i; // Si no son iguales, cogemos el último
}
}else if(arr[i]!=0){
temp = i;
}
}

temp = 0;
for(int i=0; i<4; i++) // COLOCAMOS TODOS LOS NÚMEROS AL PRINCIPIO
if(arr[i]!=0){
arr[temp++] = arr[i];
arr[i] = 0;
}

for(int i=0; i<4; i++)
std::cout << arr[i] << " ";
}


Luego tendrás que saber hacia que lado se apila y todo eso. Eso ya queda de tu mano.
#1550
Ni has explicado qué hace, ni para qué sirve, ni el nombre de la función es descriptivo.

Solo te puedo decir, que utilices un
Código (cpp) [Seleccionar]
switch(n.al[cont]){} en vez de esos if.