-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpila.c
100 lines (69 loc) · 1.87 KB
/
pila.c
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
#include "pila.h"
#include <stdlib.h>
#define CAPACIDAD_INICIAL 20
#define REDIMENSIONADOR 2
#define TAMANIO_RELATIVO 4
/* Definición del struct pila proporcionado por la cátedra.
*/
struct pila {
void** datos;
size_t cantidad; // Cantidad de elementos almacenados.
size_t capacidad; // Capacidad del arreglo 'datos'.
};
/* *****************************************************************
* PRIMITIVAS DE LA PILA
* *****************************************************************/
bool redimensionar_pila(pila_t* pila, size_t tam_nuevo){
void** datos_nuevos = realloc(pila->datos, tam_nuevo*sizeof(void*));
if(datos_nuevos == NULL){
return false;
}
pila->datos = datos_nuevos;
pila->capacidad = tam_nuevo;
return true;
}
pila_t* pila_crear(void){
pila_t* pila = malloc(sizeof(pila_t));
if(!pila) return NULL;
pila->datos = malloc(CAPACIDAD_INICIAL*sizeof(void*));
if(pila->datos == NULL){
free(pila);
return NULL;
}
pila->cantidad = 0;
pila->capacidad = CAPACIDAD_INICIAL;
return pila;
}
void pila_destruir(pila_t *pila){
free(pila->datos);
free(pila);
}
bool pila_esta_vacia(const pila_t *pila){
return (pila->cantidad == 0);
}
bool pila_apilar(pila_t *pila, void* valor){
if(pila->cantidad == pila->capacidad){
size_t tam_nuevo = pila->capacidad*REDIMENSIONADOR;
if(!redimensionar_pila(pila, tam_nuevo)){
return false;
}
}
pila->datos[pila->cantidad] = valor;
pila->cantidad++;
return true;
}
void* pila_ver_tope(const pila_t *pila){
if(pila_esta_vacia(pila)) return NULL;
return pila->datos[pila->cantidad-1];
}
void* pila_desapilar(pila_t *pila){
if(pila_esta_vacia(pila)){
return NULL;
}
if(pila->cantidad*TAMANIO_RELATIVO <= pila->capacidad){
size_t tam_nuevo = pila->capacidad/REDIMENSIONADOR;
redimensionar_pila(pila, tam_nuevo);
}
pila->cantidad--;
return pila->datos[pila->cantidad];
}