-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlab_1.cpp
154 lines (154 loc) · 3.45 KB
/
lab_1.cpp
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
151
152
153
154
#include <iostream>
#include <iomanip>
#include <fstream>
#include <stdlib.h>
using namespace std;
struct T1{
int N;
string exp, grupo, nombre;
};
typedef T1 _T1;
struct nodo{
_T1 info;
nodo* sig;
};
typedef nodo* ptnodo;
ptnodo pila1, pila2;
// funciones
void push(ptnodo &pila, T1 &elem);
void cima(ptnodo &pila,string &elem);
void pop(ptnodo &pila, T1 &elem);
void mostrar(T1 *ptregistro);
void borrar_pila(ptnodo &pila);
int main() {
string elem, cim;
int opc, i = 0;
ifstream A1;
T1 registro, *ptregistro = NULL;
while(opc != 6){
cout << "Menu de opciones\n";
cout << "1.- Cargar datos\n";
cout << "2.- Mostrar los datos cargados\n";
cout << "3.- Ordenar datos por expedientes\n";
cout << "4.- Cargar datos en una pila\n";
cout << "5.- Opcion adicional\n";
cout << "6.- Salir\n";
cin >> opc;
system("cls");
switch(opc){
case 1:
if(ptregistro != NULL){// liberar memoria
delete[] ptregistro;
}
ptregistro = new T1[27];
A1.open("lista3.txt");
if(!A1){
cout << "Error al abrir archivo";
}
A1>> ptregistro -> N;
A1.ignore(1);
getline(A1,ptregistro -> exp,'\t');
getline(A1,ptregistro -> grupo,'\t');
getline(A1,ptregistro -> nombre);
i = 1;
while(A1.eof() == 0){
A1>>ptregistro[i].N;
A1.ignore(1);
getline(A1,ptregistro[i].exp,'\t');
getline(A1,ptregistro[i].grupo,'\t');
getline(A1,ptregistro[i].nombre);
i++;
}
A1.close();
break;
case 2:
mostrar(ptregistro);
break;
case 3:
if(pila1 != NULL)
borrar_pila(pila1);
push(pila1, ptregistro[0]);
i = 1;
while (i < 27){
elem = ptregistro[i].exp;
cima(pila1, cim);
while(pila1 !=NULL && cim < elem){
pop(pila1, registro);
push(pila2, registro);
cima(pila1, cim);
}
push(pila1, ptregistro[i]);
while(pila2 != NULL){
pop(pila2, registro);
push(pila1, registro);
}
i++;
}
i = 0;
while(pila1 != NULL){
pop(pila1, ptregistro[i]);
i++;
}
mostrar(ptregistro);
break;
case 4:
if(pila1 != NULL)
borrar_pila(pila1);
for(i = 26; i >= 0; i--)
push(pila1, ptregistro[i]);
cout << "se muestran los datos almacenados en la pila\n\n";
mostrar(ptregistro);
break;
case 5:
break;
case 6:
// liberar memoria
delete[] ptregistro;
borrar_pila(pila1);
borrar_pila(pila2);
break;
default:
cout << "Ingrese una opcion valida \n\n";
break;
}
}
return 0;
}
void push(ptnodo &pila,T1 &elem){
ptnodo nuevo;
nuevo = new(nodo);
nuevo -> info = elem;
nuevo -> sig = NULL;
if(pila == NULL)
pila = nuevo;
else{
nuevo -> sig = pila;
pila = nuevo;
}
}
void cima(ptnodo &pila,string &elem){
if(pila != NULL)
elem = pila -> info.exp;
}
void pop(ptnodo &pila, T1 &elem){
ptnodo Aux = pila;
if(Aux != NULL){
pila = pila -> sig;
elem = Aux -> info;
delete(Aux);
}else{
cout << "error popa" << endl;}
}
void mostrar(T1 *ptregistro){
for(int i = 0; i < 27; i++){
cout << setw(3) << left <<ptregistro[i].N;
cout << setw(13) << ptregistro[i].exp;
cout << setw(4) << ptregistro[i].grupo;
cout << setw(24) << ptregistro[i].nombre <<endl;
}
}
void borrar_pila(ptnodo &pila){
T1 elem;
while(pila != NULL)
pop(pila, elem);
}