Lo que tu pretendes es recorrer la lista con q, luego lo único que tienes que hacer es actualizar dicho puntero en cada iteración. ¿Cómo? Muy sencillo, haciendo que apunte al elemento siguiente:
Por otro lado, si revisas un poco el bucle:
Código C++:
Ver originalwhile(pila!=NULL){
cout<<"\n solo imprimo";
cout<<"\n "<<pila->dato;
q->sig=q->sig;
}
queda claro que algo no funciona... la condición para salir del bucle depende de una variable que no se modifica dentro del bucle, luego el bucle infinito está garantizado.
Trabajar con punteros es más sencillo de lo que parece. Mira, vamos a probar a hacer esto sin punteros (una versión similar). La idea es imprimir valores hasta alcanzar un valor
Código C++:
Ver originalint q = 10;
int pila = 10;
while(pila!=0){
cout<<"\n solo imprimo";
cout<<"\n "<<pila;
q=q-1;
}
¿Funciona este código? Obviamente no. Si queremos que el bucle termine en algún momento tenemos que comprobar el estado de la variable que modificamos...
Código C++:
Ver originalint q = 10;
int pila = 10;
while(q!=0){
cout<<"\n solo imprimo";
cout<<"\n "<<pila;
q=q-1;
}
Vale, ahora ya el bucle termina pero... ¿funciona el bucle correctamente? bueeeno, tiene un pequeño problema y es que imprime el número 10 todo el rato... claro, si imprimimos una variable que no estamos actualizando dentro del bucle ¿cómo va a enterarse dicha variable de que el valor a mostrar ha cambiado?
Nuevo retoque al bucle
Código C++:
Ver originalint q = 10;
int pila = 10;
while(q!=0){
cout<<"\n solo imprimo";
cout<<"\n "<<q;
q=q-1;
}
Vaya, ahora el bucle si que funciona bien e imprime una secuencia descendente de 10 a 1. Venga, ahora que lo tenemos funcionando pasemos el código a punteros a ver que pasa:
Código C++:
Ver originalwhile(q!=nullptr){ // 1. Los punteros no se deberían comparar con 0
cout<<"\n solo imprimo";
cout<<"\n "<<q->dato; // 2. Queremos acceder a un dato concreto del puntero
q=q->sig; // 3. En las listas enlazas el cambio de puntero se hace así.
}
No ha sido tan traumático el cambio, ¿verdad? Si te cuesta trabajar con punteros, en serio, haz primero un diseño similar sin ellos y te acabarás dando cuenta de que no son tan diferentes a las variables locales de toda la vida.
PD.: nullptr lleva en C++ desde que vió la luz el estándar C++11 (efectivamente, en 2011), por lo que cualquier compilador posterior lo debería soportar (en algunos casos hay que activar el estándar a mano con un flag al compilar). Simplemente que sepas que está ahí y que debería ser la forma habitual de trabajar con punteros. No estaría de más que vuestro profesor os enseñase los detalles del lenguaje actual y no una versión que data del siglo pasado.
Un saludo.