//****************************//
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include<conio.h>
#include <iostream>
using namespace std;
typedef struct dato nodo;
nodo* crear_lista(nodo* lista);
nodo* ingresar_dato(char* nombre, int boleta, nodo* lista);
void mostrar_lista(nodo* lista);
void mostrar_nodo(nodo* elemento);
void menu(void);
void borrar_lista(nodo* lista);
nodo* borrar_nodoxnombre(char *nombre, nodo* lista);
nodo* borrar_nodoxnota(int boleta, nodo* lista);
nodo* buscar_nodo(nodo* lista, char *caracter);
void ordenar_lista(nodo* lista);
struct dato
{
char nombre[80];
int nota;
struct dato *sig;
};
nodo* crear_lista(nodo* lista)
{
return (lista = null);
}
nodo* ingresar_dato(char* nombre, int boleta, nodo* lista)
{
nodo *nuevo_dato;
nodo *auxiliar = null;
nuevo_dato
= (nodo
*)malloc(sizeof(nodo
));
if(nuevo_dato != null)
{
strcpy((nuevo_dato
->nombre
), nombre
); nuevo_dato->nota = boleta;
nuevo_dato->sig = null;
if(lista == null)
lista = nuevo_dato;
else
{
auxiliar = lista;
while(auxiliar->sig != null)
auxiliar = auxiliar->sig;
auxiliar->sig = nuevo_dato;
}
}
else
cout<<"\n\nno se pudo reservar memoria\n\n";
return lista;
}
void mostrar_lista(nodo* lista)
{
nodo *auxiliar;
int contador = 0;
if(lista == null)
cout<<"\n\nla lista esta vacia\n\n";
auxiliar = lista;
while(auxiliar != null)
{
cout<<"\n\npersona"<<(contador+1);
cout<<"\nnombre y apellido: "<<auxiliar->nombre;
cout<<"\n\nboleta: "<< auxiliar->nota;
contador++;
auxiliar = auxiliar->sig;
}
cout<<"\nfin de lista\n\n";
}
void borrar_lista(nodo* lista)
{
nodo *borra;
borra = lista;
while(borra)
{
lista = lista->sig;
borra = lista;
}
}
void menu(void)
{
cout<<"\n\nlista_practica_3 3cm7:\n\n";
cout<<"1) ingresar dato\n";
cout<<"2) mostrar lista\n";
cout<<"3) borrar lista\n";
cout<<"4) borrar por nombre\n";
cout<<"5) borrar por boleta\n";
cout<<"6) buscar en lista\n";
cout<<"7) ordenar lista\n";
cout<<"0)salir\n\n";
}
nodo* borrar_nodoxnombre(char *nombre, nodo* lista)
{
if(lista != null)
{
nodo *ptraux;
nodo *ptranterior = null;
int cont;
ptraux = lista;
while(ptraux
!= null && (strcmp(ptraux
->nombre
, nombre
) != 0)) {
ptranterior = ptraux;
ptraux = ptraux->sig;
cont++;
}
if(cont == 1 && ptraux->sig == null)
{
lista = null;
}
if(ptraux == null)
cout<<"\n\nno se encontro una persona con ese nombre\n\n";
else if(ptranterior == null)
{
lista = lista->sig;
}
else
{
ptranterior->sig = ptraux->sig;
}
}
return lista;
}
nodo* borrar_nodoxnota(int boleta, nodo* lista)
{
if(lista != null)
{
nodo *ptraux;
nodo *ptranterior = null;
int cont = 0;
ptraux = lista;
while(ptraux != null && ptraux->nota != boleta)
{
ptranterior = ptraux;
ptraux = ptraux->sig;
cont++;
}
if(cont == 1 && ptraux->sig == null)
{
lista = null;
}
if(ptraux == null)
cout<<"\n\nno se encontro una persona con ese numero de boleta\n\n";
else if(ptranterior == null)
{
lista = lista->sig;
}
else
{
ptranterior->sig = ptraux->sig;
}
}
return lista;
}
nodo* buscar_nodo(nodo* lista, char *caracter)
{
nodo *aux;
char noabuscar[20];
char a[] = "a";
char b[] = "b";
int nabuscar;
if(lista != null)
{
{
cout<<"\n\ningrese el nombre a buscar: ";
fgets(noabuscar
, 20, stdin
); aux = lista;
while(aux != null)
{
if(strcmp(aux
->nombre
, noabuscar
) == 0) return aux;
aux = aux->sig;
}
return aux;
}
else if(strcmp(caracter
,b
) == 0) {
cout<<"\n\ningrese la nota a buscar: ";
cout<<nabuscar;
aux = lista;
while(aux != null)
{
if(aux->nota == nabuscar)
return aux;
aux = aux->sig;
}
return aux;
}
else
{
cout<<"\n\nopcion no valida\n\n";
return 0;
}
}
}
void mostrar_nodo(nodo* elemento)
{
nodo* nodoencontrado;
nodoencontrado = elemento;
if(nodoencontrado == null)
cout<<"\n\nno se obtuvieron resultados\n\n";
else
{
cout<<"\n\nnodo encontrado:\n\n";
cout<<"\nnompre y apellido:"<< nodoencontrado->nombre;
cout<<"\nboleta: "<< nodoencontrado->nota;
}
}
/* \n\n\n\n */
void ordenar_lista(nodo* lista)
{
nodo *anterior;
nodo *siguiente;
nodo temp;
anterior = lista;
while(anterior->sig != null)
{
siguiente = anterior->sig;
while(siguiente != null)
{
if(strcmp(anterior
->nombre
, siguiente
->nombre
) > 0) {
strcpy(temp.
nombre, siguiente
->nombre
); temp.nota = siguiente->nota;
strcpy(siguiente
->nombre
, anterior
->nombre
); siguiente->nota = anterior->nota;
strcpy(anterior
->nombre
, temp.
nombre); anterior->nota = temp.nota;
}
siguiente = siguiente->sig;
}
anterior = anterior->sig;
siguiente = anterior->sig;
}
cout<<"\n\nlista ordenada\n\n";
}
int main(int argc, char** argv)
{
nodo *inicio;
nodo *nodobuscado;
char nom[20];
char nomaborrar[20];
int nborrar;
int nota, i, cant, op;
char s[2];
inicio = crear_lista(inicio);
menu();
cin>>op;
while(op != 0)
{
switch(op)
{
case 1: Cout<<"\n\nque cantidad de datos ingresara: ";
cin>>cant;
cout<<"\n\n";
cout<<"ingreso de datos:\n\n";
for(i=0 ; i < cant ; i++)
{
cout<<"nombre y apellido: ";
cout<<"\nboleta: ";
cin>>nota;
cout<<"\n\n";
inicio = ingresar_dato(nom, nota, inicio);
}
break;
case 2: Mostrar_lista(inicio);
break;
case 3: Borrar_lista(inicio);
cout<<"\n\nlista borrada\n\n";
inicio = null;
break;
case 4: Cout<<"\n\ningrese el nombre a borrar\n\n";
fgets(nomaborrar
, 80, stdin
); inicio = borrar_nodoxnombre(nomaborrar, inicio);
break;
case 5: Cout<<"\n\ningrese la nota a borrar\n\n";
cin>>nborrar;
inicio = borrar_nodoxnota(nborrar, inicio);
break;
case 6: Cout<<"\n\n('a') para buscar por nombre || ('b') para buscar por nota\n\n";
nodobuscado = buscar_nodo(inicio, s);
mostrar_nodo(nodobuscado);
break;
case 7: Ordenar_lista(inicio);
break;
default: Cout<<"\n\n este no es una opcion, intentelo nuevamente// \n\n";
}
menu();
cin>>op;
}
return (exit_success);
}