Autor
|
Tema: Problema contador en C (Leído 9,723 veces)
|
People95
Desconectado
Mensajes: 10
|
Buenas, tengo una matriz de 0 y 1, donde los 0 se convierten en "." y los 1 en "X", pues tengo que dejar caer una bola desde arriba y como si fuera un pinball ir rebotando simulando las X como obstaculos, algo así: Pero no consigo aplicar el contador que vaya bajando, todo el rato me da error, alguien me puede ayudar? Esto es lo que llevo: #include <stdio.h> void intercambia(int *a, int *b); void dir(char c); int main() { int inicio,i,j,contador; char direccion; int matriu[10][10]={ {0,0,0,0,0,0,0,0,0,0}, {0,1,0,0,1,0,0,0,1,0}, {0,1,0,1,0,0,0,1,0,0}, {0,1,0,0,0,0,1,0,0,0}, {0,0,0,0,0,0,0,0,0,1}, {0,1,1,1,1,0,0,0,1,0}, {0,0,0,0,0,0,0,1,0,0}, {0,0,0,0,0,0,1,0,0,0}, {0,0,0,0,0,1,0,0,0,0}, {0,0,0,0,0,0,0,0,0,0}, }; do{ printf("\nIntroducir el numero de columna por el cual desea lanzar la primera bola: "); scanf("%d",&inicio); }while(inicio>=9); do{ printf("\nEn caso de encontrarse con un obstaculo, en que direccion quiere que se dirija la bola, derecha (D) o izquierda (I): "); fflush(stdin); scanf("%c", &direccion); }while(direccion!='D' && direccion!='d' && direccion!='I' && direccion!='i'); inicio=matriu[0][inicio]; contador=0; while(i++){ contador +=1; } intercambia( &inicio, &contador); for(i=0;i<10;i++) { printf("\t"); for(j=0;j<10;j++) { //if(matriu [j]==matriu[0][inicio]) // printf("%d ",contador); if(matriu[j]==1) printf("X "); if(matriu[j]==0) printf(". "); } printf("\n"); }
contador=0; while(i++){ contador +=1; } }
void intercambia(int *a,int *b){ //a será el valor de la matriz y b el valor del contador
*a=*b; }
void dir(char c){ int j; char direccion;
if(direccion!='D' && direccion!='d'){ j+=1; } else j-=1; }
|
|
|
En línea
|
|
|
|
ivancea96
Desconectado
Mensajes: 3.412
ASMático
|
void intercambia(int *a,int *b){ //a será el valor de la matriz y b el valor del contador
*a=*b; } Ahí por ejemplo, no intercambias. solo asignas
|
|
|
En línea
|
|
|
|
People95
Desconectado
Mensajes: 10
|
Pero sigo sin saber como poder "imprimir" el contador y que vaya bajando, solo llevo un par de semanas programando, he pensado algo así:
do{ printf("\nIntroducir el numero de columna por el cual desea lanzar la primera bola: "); scanf("%d",&inicio); }while(inicio>=9);
do{ printf("\nEn caso de encontrarse con un obstaculo, en que direccion quiere que se dirija la bola, derecha (D) o izquierda (I): "); fflush(stdin); scanf("%c", &direccion); }while(direccion!='D' && direccion!='d' && direccion!='I' && direccion!='i'); inicio=matriu[0][inicio];
contador=0; while(i++){ contador +=1; }
intercambia(&inicio, &contador);
for(i=0;i<10;i++) { printf("\t"); for(j=0;j<10;j++) { if(matriu[j]==1) printf("X "); else { if(matriu(i)[j] == matriu(i)[inicio]) printf("&d",contador"); else (matriu(i)[j]==0 && matriu(i)[j]==0 != matriu(i)[inicio]) printf(". "); } }printf("\n"); } } El problema es lo que está en negrita, no sé como puedo hacer que imprima el contador por la posición que elija el usuario, solo se me ocurre matriu[inicio] y dudo que esté bien
EDITO: Todas las (i) de la matriz estan en parentesis pq al publicarla aqui se me comia si lo ponia en corchetes
|
|
« Última modificación: 1 Marzo 2014, 19:57 pm por People95 »
|
En línea
|
|
|
|
leosansan
Desconectado
Mensajes: 1.314
|
Cuando postees el código elige las etiquetas GeSHi y toma la C++ y en medio de las etiquetas Code que aparecen "pegas" tu código. Al no hacerlo de esta manera parte del código no sale correcta, especialmente las matrices.¡¡¡¡ Saluditos! ..... !!!!
|
|
|
En línea
|
|
|
|
People95
Desconectado
Mensajes: 10
|
Gracias!!!! A ver ai ahora... do{ printf("\nIntroducir el numero de columna por el cual desea lanzar la primera bola: "); scanf("%d",&inicio); }while(inicio>=9); do{ printf("\nEn caso de encontrarse con un obstaculo, en que direccion quiere que se dirija la bola, derecha (D) o izquierda (I): "); fflush(stdin); scanf("%c", &direccion); }while(direccion!='D' && direccion!='d' && direccion!='I' && direccion!='i'); inicio=matriu[0][inicio]; contador=0; while(i++){ contador +=1; } for(i=0;i<10;i++) { printf("\t"); for(j=0;j<10;j++) { //if(matriu[i][j]==matriu[0][inicio]) // printf("%d ",contador); if(matriu[i][j]==1) printf("X "); else { if(matriu[i][j] == matriu[i][inicio]) printf("&d",contador"); else (matriu[i][j]==0 && matriu[i][j]==0 != matriu[i][inicio]) printf(". "); }}printf("\n"); } contador=0; while(i++){ contador +=1; } }
|
|
|
En línea
|
|
|
|
ivancea96
Desconectado
Mensajes: 3.412
ASMático
|
contador=0; while(i++){ contador +=1; } }
Eso que hace? Qué quieres que cuente tu contador??? Número de pasos?
|
|
|
En línea
|
|
|
|
People95
Desconectado
Mensajes: 10
|
Exacto, por cada paso que da hacia bajo o hacia derecha/izquierda sumar 1
|
|
|
En línea
|
|
|
|
ivancea96
Desconectado
Mensajes: 3.412
ASMático
|
En prime lugar: contador=0; while(i++){ contador +=1; }
En ningún momento inicializas i. Igualmente, esas líneas son absurdas. ¿Qué pretendías que hicieran? En segundo lugar: Para poner un contador, simplemente empieza en 0, y ve subiendolo en cada movimiento.
|
|
|
En línea
|
|
|
|
leosansan
Desconectado
Mensajes: 1.314
|
Exacto, por cada paso que da hacia bajo o hacia derecha/izquierda sumar 1
Pero para eso tiene que dar previamente un paso, no puedes ponerlo como algo suelto.
Aunque el código que cuelgas está verde, la verdad es que me ha resultado interesante, o más bien curioso, el ejercicio.
Así que he decidido madurarlo un poco. Tal y como está es funcional, pero muy mejorable, vamos que también está verde .... pero funciona. Ya te toca a ti mejorarlo un poco, al menos tienes una referencia de cómo atacarlo, una al menos.
Fíjate en el detalle de que el contador lo comienzo en dos, ya luego resto justamente dos. ¿Y porqué ese capricho?. Para que no salgan el cero y el uno y se confundan con los ceros y unos que ya habían en la matriz. Una picardía sin más.
Por cierto, no has dejado en la matriz inicial más que un camino, la columna 1, para recorrer el pinball si eliges a la derecha y llegar al final. Creo que deberías cambiar/disminuir los 1 o X.
Y una imagen de que furula:#include <stdio.h> int main() { int inicio,i,j,cont=0,flag=0; char direccion; int matriu[10][10]={ {0,0,0,0,0,0,0,0,0,0}, {0,1,0,0,1,0,0,0,1,0}, {0,1,0,1,0,0,0,1,0,0}, {0,1,0,0,0,0,1,0,0,0}, {0,0,0,0,0,0,0,0,0,1}, {0,1,1,1,1,0,0,0,1,0}, {0,0,0,0,0,0,0,1,0,0}, {0,0,0,0,0,0,1,0,0,0}, {0,0,0,0,0,1,0,0,0,0}, {0,0,0,0,0,0,0,0,0,0}, }; do{ printf("\nIntroducir el numero de columna por el cual desea lanzar la primera bola (1-10): "); scanf("%d",&inicio); }while(inicio>=11); inicio--; do{ printf("\nEn caso de encontrarse con un obstaculo, en que direccion\n quiere que se dirija la bola, derecha (D-d) o izquierda (I-i): "); scanf(" %c", &direccion); }while(direccion!='D' && direccion!='d' && direccion!='I' && direccion!='i'); for(i=0;i<10;i++) { printf("\t\t"); for(j=0;j<10;j++) { if(matriu[i][j]==1) printf("X "); else printf(". "); } printf("\n"); } i=0,j=inicio,cont=2; matriu[i][j]=cont++; while(i<9){ if ((j==-1 || j==10) ){ puts("FIN ANTES DE TIEMPO"); flag=1; break; } else if (matriu[i+1][j]==0) matriu[++i][j]=cont++; else if (direccion=='D' || direccion=='d'&& matriu[i][j+1]==0 ) matriu[i][++j]=cont++; else if (direccion=='D' || direccion=='d'&& matriu[i][j+1]==1 ){ puts("FIN ANTES DE TIEMPO"); flag=1; break; } else if (direccion=='I' || direccion=='i' && matriu[i][j-1]==0) matriu[i][--j]=cont++; else if (direccion=='I' || direccion=='i' && matriu[i][j-1]==1){ puts("FIN ANTES DE TIEMPO"); flag=1; break; } } if (flag==0) puts("FINAL EXITOSO"); for(i=0;i<10;i++) { printf("\t\t"); for(j=0;j<10;j++) { if(matriu[i][j]==1) printf("X "); else if(matriu[i][j]==0 ) printf(". "); else printf("%d ",matriu[i][j]-2); } printf("\n"); } return 0; }
Mejora lo, es lo que me ha salido a bote pronto y a estas horas ya estoy de retirada.¡¡¡¡ Saluditos! ..... !!!!
|
|
|
En línea
|
|
|
|
People95
Desconectado
Mensajes: 10
|
Muchiiiisimas gracias! No sabes cuanto me has ayudado, ahora tengo otro problema y es que en una matriz de 50x50 haga que el programa pida una fila y columna de algun valor que desea modificar, de forma que si antes habia un 0, se convertirá en un 1 (y por tanto un obstaculo) y viceversa. Ademas el programa debe comprobar que la bola siempre caerá, y si es legal (que la bola siempre cae) enseñar la nueva tabla. Tengo esto: void cambiartabla (int matriu[50][50]){ int i,j,fila,columna,error=0; char seguir; while(seguir!=2) { printf("Presiona 1 si quieres seguir cambiando valores.\n"); printf("Presiona 2 si quieres ver la tabla.\n"); switch(seguir) { case 1: do{ printf("\nIntroducir la fila del valor que quieres cambiar (1-50): "); printf("\nIntroducir la columna del valor que quieres cambiar (1-50): "); }while(columna>=51 && fila>=51); break; default: printf("El numero introducido es incorrecto.\n"); } } i=columna,j=fila; if (matriu[i][j] = 0) matriu[i][j] = 1; else matriu[i][j] = 0; while(i<49){ if (matriu[i+1][j]==1 && matriu[i-1][j]==1 && matriu[i][j-1]==1) error=1; break; } for(i=0;i<50;i++) { for(j=0;j<50;j++) { if(matriu[i][j]==1) else if(matriu[i][j]==0 ) } } }
Pero al compilar me sigue dando la tabla igual, no me cambia los valores, por tanto creo que el fallo está aquí: i=columna,j=fila; if (matriu[i][j] = 0) matriu[i][j] = 1; else matriu[i][j] = 0;
Como lo puedo solucionar???
|
|
« Última modificación: 2 Marzo 2014, 20:10 pm por People95 »
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
Problema con contador en C
« 1 2 »
Programación C/C++
|
-/lnkx/-
|
12
|
20,897
|
7 Diciembre 2011, 18:53 pm
por A.ABAENA
|
|
|
Problema con contador, displays de 7 segmentos
ASM
|
dragonlady
|
0
|
2,336
|
21 Junio 2015, 20:07 pm
por dragonlady
|
|
|
Problema contador python
Scripting
|
runas3
|
6
|
4,872
|
1 Junio 2017, 12:53 pm
por runas3
|
|
|
Problema con contador en batch.
Scripting
|
Ezko
|
2
|
4,417
|
11 Mayo 2018, 18:58 pm
por Ezko
|
|
|
problema con contador que toma segundos del sistema
ASM
|
FERNIIIIN
|
3
|
2,365
|
28 Mayo 2019, 23:39 pm
por xv0
|
|