Operación y mantenimiento de una lista

c:
#include <stdio.h>
#include <stdlib.h>

/* estructura auto_referenciada */
struct nodoLista {           
   char dato; /* cada nodoLista contiene un caracter */
   struct nodoLista *ptrSiguiente; /* apuntador al siguiente nodo */
}; /* fin de la estructura nodoLista */

typedef struct nodoLista NodoLista; /* sinónimo para la estructura nodoLista */
typedef NodoLista *ptrNodoLista; /* sinónimo para de NodoLista* */

/* prototipos */
void insertar( ptrNodoLista *ptrS, char valor );
char eliminar( ptrNodoLista *ptrS, char valor );
int estaVacia( ptrNodoLista ptrS );
void imprimeLista( ptrNodoLista ptrActual );
void instrucciones( void );

int main()
{
   ptrNodoLista ptrInicial = NULL; /* inicialmente no existen nodos */
   int eleccion;  /* eleccion del usuario */
   char elemento; /* carácter introducido por el usuario */

   instrucciones(); /* despliega el menú */
   printf( "? " );
   scanf( "%d", &#038;eleccion );

   /* repite mientras el usuario no elija 3 */
   while ( eleccion != 3 ) {

      switch ( eleccion ) {

         case 1:
            printf( "Introduzca un caracter: " );
            scanf( "\n%c", &#038;elemento );
            insertar( &#038;ptrInicial, elemento ); /* inserta el elemento en la lista */
            imprimeLista( ptrInicial );
            break;

         case 2:

            /* si la lista no esta vacía */
            if ( !estaVacia( ptrInicial ) ) {
               printf( "Introduzca un caracter para eliminar: " );
               scanf( "\n%c", &#038;elemento );

               /* si encuentra el caracter, lo remueve */
               if ( eliminar( &#038;ptrInicial, elemento ) ) { /* elimina elemento */
                  printf( "caracter %c eliminado.\n", elemento );
                  imprimeLista( ptrInicial );
               } /* fin de if */
               else {
                  printf( "no se encuentra el caracter %c.\n\n", elemento );
               } /* fin de else */

            } /* fin de if */
            else {
               printf( "La lista esta vacia.\n\n" );
            } /* fin de else */

            break;

         default:
            printf( "Opcion invalida.\n\n" );
            instrucciones();
            break;
     
      } /* fin de switch */

      printf( "? " );
      scanf( "%d", &#038;eleccion );
   } /* fin de while */

   printf( "Fin de la ejecucion.\n" );
   
   return 0; /* indica terminación exitosa */

} /* fin de main */

/* despliega las instrucciones del programa para el usuario */
void instrucciones( void )
{
   printf( "Introduzca su eleccion:\n"
      "   1 para insertar un elemento en la lista.\n"
      "   2 para eliminar un elemento de la lista.\n"
      "   3 para terminar.\n" );
} /* fin de la función instrucciones */

/* Inserta un nuevo valor dentro de la lista en orden  */
void insertar( ptrNodoLista *ptrS, char valor )
{
   ptrNodoLista ptrNuevo;    /* apuntador a un nuevo nodo */
   ptrNodoLista ptrAnterior; /* apuntador a un nodo previo de la lista */
   ptrNodoLista ptrActual;   /* apuntador al nodo actual de la lista */

   ptrNuevo = malloc( sizeof( NodoLista ) ); /* crea un nodo */

   if ( ptrNuevo != NULL ) {    /* es espacio disponible */
      ptrNuevo->dato = valor;   /* coloca el valor en el nodo */
      ptrNuevo->ptrSiguiente = NULL; /* el nodo no se liga a otro nodo */

      ptrAnterior = NULL;
      ptrActual = *ptrS;

      /* ciclo para localizar la ubicación correcta en la lista */
      while ( ptrActual != NULL &#038;&#038; valor > ptrActual->dato ) {
         ptrAnterior = ptrActual;          /* entra al ...   */
         ptrActual = ptrActual->ptrSiguiente;  /* ... siguiente nodo */
      } /* fin de while */

      /* inserta un nuevo nodo al principio de la lista */
      if ( ptrAnterior == NULL ) {
         ptrNuevo->ptrSiguiente = *ptrS;
         *ptrS = ptrNuevo;
      } /* fin de if */
      else { /* inserta un nuevo nodo entre ptrAnterior y ptrActual */
         ptrAnterior->ptrSiguiente = ptrNuevo;
         ptrNuevo->ptrSiguiente = ptrActual;
      } /* fin de else */
   
   } /* fin de if */
   else {
      printf( "No se inserto %c. No hay memoria disponible.\n", valor );
   } /* fin de else */

} /* fin de la función insertar */

/* Elimina un elemento de la lista */
char eliminar( ptrNodoLista *ptrS, char valor )
{
   ptrNodoLista ptrAnterior; /* apuntador a un nodo previo de la lista */
   ptrNodoLista ptrActual;   /* apuntador al nodo actual de la lista */
   ptrNodoLista tempPtr;     /* apuntador a un nodo temporal */

   /* elimina el primer nodo */
   if ( valor == ( *ptrS )->dato ) {
      tempPtr = *ptrS; /* almacena el nodo a eliminar */
      *ptrS = ( *ptrS )->ptrSiguiente; /* desata el nodo */
      free( tempPtr ); /* libera el nodo desatado */
      return valor;
   } /* fin de if */
   else {
      ptrAnterior = *ptrS;
      ptrActual = ( *ptrS )->ptrSiguiente;

      /* ciclo para localizar la ubicación correcta en la lista */
      while ( ptrActual != NULL &#038;&#038; ptrActual->dato != valor ) {
         ptrAnterior = ptrActual;         /* entra al ...   */
         ptrActual = ptrActual->ptrSiguiente; /* ... siguiente nodo */
      } /* fin de while */

      /* elimina el nodo de ptrActual */
      if ( ptrActual != NULL ) {
         tempPtr = ptrActual;
         ptrAnterior->ptrSiguiente = ptrActual->ptrSiguiente;
         free( tempPtr );
         return valor;
      } /* fin de if */
     
   } /* fin de else */

   return '\0';

} /* fin de la función eliminar */

/* Devuelve 1 si la lista esta vacía, de lo contrario, 0  */
int estaVacia( ptrNodoLista ptrS )
{
   return ptrS == NULL;

} /* fin de la función function estaVacia */

/* Imprime la lista */
void imprimeLista( ptrNodoLista ptrActual )
{

   /* si la lista esta vacía */
   if ( ptrActual == NULL ) {
      printf( "La lista esta vacia.\n\n" );
   } /* fin de if */
   else {
      printf( "La lista es:\n" );

      /* mientras no sea el final de la lista */
      while ( ptrActual != NULL ) {
         printf( "%c --> ", ptrActual->dato );
         ptrActual = ptrActual->ptrSiguiente;   
      } /* fin de while */

      printf( "NULL\n\n" );
   } /* fin de else */

} /* fin de la función imprimeLista */
¿Ya le viste algún error? Dejanos tu correción ;-)

Antes de comentar: Gran parte de los ejercicios propuestos no tienen librerías debido a que Wordpress elimina los tags HTML. Si sabes/tienes/conoces las librerías que hacen falta, déjalo en los comentarios.

Otro punto antes de comentar, Si vas a sugerir un segmento de código en algún lenguaje debes hacerlo así:

De esta manera el código sale coloreado.

Otro punto importante para muchos que sienten que se les ignora: Todos los comentarios los reviso y en su debido momento los apruebo, pero ojo con el último párrafo.

Para poner los símbolos de las librerías sin que desaparezcan, debes escribir los símbolos de mayor > y menor qué < con su entidad HTML correspondiente, así como el símbolo de &

Mis Algoritmos se reserva el derecho de alterar, publicar o no los comentarios así como cambiar estas reglas de uso.

Si estas de acuerdo, adelante puedes comentar :)

P.D. No le hago tareas a nadie, mejor hagan la mía :P