C/Visual C - Necesito Ayuda con mi ERROR en pilas de C

 
Vista:

Necesito Ayuda con mi ERROR en pilas de C

Publicado por ml0x (1 intervención) el 10/04/2016 08:33:52
Hola tengo una duda, al imprimir mi pila se cae el programa y no entiendo por que ! me estoy frustrando, agradecería muchísimo su ayuda. de ante mano Muchas gracias!


Aquí les va mi código !!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#include <stdio.h>
#include <stdlib.h>
 
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
 
//creacion de la estructura
typedef struct Pila {
    int *dato;
    struct Pila *sgte;
}Pila;
 
//asignacion de memoria
Pila *asignarMemoria(){
	return (Pila *)malloc(sizeof(Pila));
}
 
//apilado
Pila *apilar(Pila *p, int dato){
 
	Pila *q = asignarMemoria(); //Pila auxiliar
	q->dato=dato;
	q->sgte=NULL;
 
	if(p==NULL){
		return q;
	}
	q->sgte = p;
	p = q;
	return p;
}
 
//desapilado
Pila *desapilar(Pila *p){
 
	if(p == NULL){
		return p;
	}
	Pila *q = p->sgte;
	p->sgte = NULL;
	free(p); //liberar memoria
	return q;
}
 
//listar la pila
void mostrarPila (Pila *p){
 
	if(p!=NULL){
		Pila *q = p; //pila auxiliar
		while(q!=NULL){
			printf("%d ", q->dato);
			q = desapilar(q);
			}
		return;
	}
	printf("No hay elementos en la Pila\n");
}
//buscar un elemento en la pila
int buscarPila(Pila *p, int dato){
	if(p!=NULL){
		Pila *q = p; //pila auxiliar
		while(q!=NULL){
			if(q->dato==dato){
				return 1; //verdadero si lo encuentra.
			}
			q = desapilar(q);
		}
		return 0; //falso, si no lo encuentra.
	}
	return 0; //falso, si no lo encuentra.
}
 
int main(int argc, char *argv[]) {
 
	//Menu Principal.
	int opcionMenu, volverIntentar, scanfValidador;
	srand(time(NULL));  //Semilla del creador de numeros Randoms
 
do{
	do{
 
	printf("Seleccione una opcion\n");
	printf("[1] Ejercicio 1\n[2] Ejercicio 2\n[3] Ejercicio 3\n[4] Salir\n");
	scanfValidador = scanf("%d", &opcionMenu);
	fflush(stdin);
		if(scanfValidador!=1){
			printf("\nOpcion no valida, ingrese un valor numererico positivo.\n");
			puts("");
		}
	}while(scanfValidador!=1); //Validador
 
   		if(opcionMenu == 1){
    	 // Crear y listar una pila con n elementos. Ingresar un dato y consultar cuantas veces se repite y en que posiciones.
			Pila *pila;
			int n, i; //tamaño n de la pila
			int numRand;
			int scanfValidador3;
 
			do{
      		puts("Ingrese tamaño de la Pila la cual tendra numeros random del [0-10]");
      		scanfValidador3 = scanf("%d", &n);
      		fflush(stdin);
      		if(scanfValidador3!=1){
      			printf("\nOpcion no valida, ingrese un valor numererico positivo.\n");
      			puts("");
			}
      		}while(scanfValidador3!=1); //Validador
      		i=n;
 
      		while(n!=0){ //Recorrer Pila
      			numRand = rand() % 11; // genera un numero Random entre el 0 y el 10
      			//pila->sgte=NULL;
      			pila = apilar(pila, numRand);
				n--;
			}
			while(i!=0){
				mostrarPila(pila);
				i--;
			}
		}
 
		else if(opcionMenu == 2){
			printf("Opcion 2\n");
		}
 
		else if(opcionMenu == 3){
			printf("Opcion 3\n");
		}
 
		else if(opcionMenu == 4){
			exit(0);
		}
		else{
			puts("");
			printf("Opcion invalida\n");
			puts("");
		}
		int scanfValidador2;
	do{
		printf("\nPara volver a intentar preciona [1] y da enter.\nPara salir use cualquier otro numero y precione enter.\n");
		puts("");
		scanfValidador2 = scanf("%d", &volverIntentar);
		fflush(stdin);
		if(scanfValidador2!=1){
			printf("\nOpcion no valida, ingrese un valor numererico positivo.\n");
			puts("");
		}
	}while(scanfValidador2!=1); //Validador
}while(volverIntentar==1);
	return 0;
}
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
sin imagen de perfil
Val: 296
Bronce
Ha mantenido su posición en C/Visual C (en relación al último mes)
Gráfica de C/Visual C

Necesito Ayuda con mi ERROR en pilas de C

Publicado por agustin (272 intervenciones) el 10/04/2016 11:46:22
Lo primero que he visto y no me cuadra es esto en desapilar pila:
p->sgte = NULL;
La lógica es que liberas la memoria de p pero antes para no romper la lista pasas la dirección del siguiente elemento pero si después haces eso estas rompiendo la lista ya que q saldrá si o si apuntando a null.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar
sin imagen de perfil
Val: 296
Bronce
Ha mantenido su posición en C/Visual C (en relación al último mes)
Gráfica de C/Visual C

Necesito Ayuda con mi ERROR en pilas de C

Publicado por agustin (272 intervenciones) el 10/04/2016 12:02:57
Otras cositas ¿que sentido tienen los puts("")?
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

Necesito Ayuda con mi ERROR en pilas de C

Publicado por Chema (234 intervenciones) el 10/04/2016 17:49:19
La pila no "pilila".
Si apilas pilas de código sin sentido , es normal que no "pilile" la cosa.
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar