Hola a todos, de pronto alguien que me pueda ayudar con este problema, tengo la siguiente estructura:
/*INICIO Estructura Proveedores*/
struct Proveedores
{
char Nombre[50];
int long Nit;
char Direccion[50];
int long Telefono;
char TipoProducto[150];
struct Proveedores *siguiente;//Puntero de la siguiente entrada
//struct Provedores *anterior; //Puntero de la entrada anterior
};
Proveedores *primero, *ultimo;
En la cual ingreso datos, visualizo y elimino datos con listas enlazadas; ya realice la de ingresar y visualizar; pero la de eliminar no me ha dado: este es el código de dicha función:
void EliminarProveedor()
{
int DatoAEliminar, contador, numelementos;
Proveedores *ultimo, *GenerarReporte;
contador=0;
ultimo=NULL; //apuntador que apunta al registro anterior
GenerarReporte=primero; //apuntador que se va a ir moviendo.... pNodo siempre apunta al principio
numelementos = VisualizarProveedor(); //Muestra los datos como referencia al usuario.
cout<< "\n\r Dame el ID del proveedor: ";
cin>> DatoAEliminar;
if (DatoAEliminar>numelementos){ //si seleccionan una opcion que no esta
cout<< "Dicho ID de proveedor no existe, seleccione uno de la lista"; //saca el mensaje en pantalla y retorna
return EliminarProveedor();
}
while (GenerarReporte)
{
++contador;
if (contador == DatoAEliminar){ // si lo encontra, entonces lo borra
if (primero->siguiente == NULL) { //Es el primer elemento y el unico
primero=NULL;
//return;
}
if (primero->siguiente == GenerarReporte->siguiente){ //es el primero
primero=GenerarReporte->siguiente;
//return 0;
}
if (GenerarReporte->siguiente != NULL){ // si esta en el medio a borrar
ultimo->siguiente=GenerarReporte->siguiente;
GenerarReporte=NULL;
//return 0;
} else { //es el ultimo
ultimo->siguiente=NULL;
GenerarReporte=NULL;
// return 0;
}
}
//se va al siguiente
ultimo=GenerarReporte;
GenerarReporte=GenerarReporte->siguiente;
}
}