-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlistaSimbolos.c
92 lines (78 loc) · 1.83 KB
/
listaSimbolos.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
#include "listaSimbolos.h"
#include <stdlib.h>
#include <string.h>
#include <assert.h>
struct PosicionListaRep {
Simbolo dato;
struct PosicionListaRep *sig;
};
struct ListaRep {
PosicionLista cabecera;
PosicionLista ultimo;
int n;
};
typedef struct PosicionListaRep *NodoPtr;
Lista creaLS() {
Lista nueva = malloc(sizeof(struct ListaRep));
nueva->cabecera = malloc(sizeof(struct PosicionListaRep));
nueva->cabecera->sig = NULL;
nueva->ultimo = nueva->cabecera;
nueva->n = 0;
return nueva;
}
void liberaLS(Lista lista) {
while (lista->cabecera != NULL) {
NodoPtr borrar = lista->cabecera;
lista->cabecera = borrar->sig;
free(borrar);
}
free(lista);
}
void insertaLS(Lista lista, PosicionLista p, Simbolo s) {
NodoPtr nuevo = malloc(sizeof(struct PosicionListaRep));
nuevo->dato = s;
nuevo->sig = p->sig;
p->sig = nuevo;
if (lista->ultimo == p) {
lista->ultimo = nuevo;
}
(lista->n)++;
}
void suprimeLS(Lista lista, PosicionLista p) {
assert(p != lista->ultimo);
NodoPtr borrar = p->sig;
p->sig = borrar->sig;
if (lista->ultimo == borrar) {
lista->ultimo = p;
}
free(borrar);
(lista->n)--;
}
Simbolo recuperaLS(Lista lista, PosicionLista p) {
assert(p != lista->ultimo);
return p->sig->dato;
}
PosicionLista buscaLS(Lista lista, char *nombre) {
NodoPtr aux = lista->cabecera;
while (aux->sig != NULL && strcmp(aux->sig->dato.nombre,nombre) != 0) {
aux = aux->sig;
}
return aux;
}
void asignaLS(Lista lista, PosicionLista p, Simbolo s) {
assert(p != lista->ultimo);
p->sig->dato = s;
}
int longitudLS(Lista lista) {
return lista->n;
}
PosicionLista inicioLS(Lista lista) {
return lista->cabecera;
}
PosicionLista finalLS(Lista lista) {
return lista->ultimo;
}
PosicionLista siguienteLS(Lista lista, PosicionLista p) {
assert(p != lista->ultimo);
return p->sig;
}