Jump to content
thinkabout

Remover o último elemento da lista.

Recommended Posts

thinkabout

Não estou a ver como consigo correr todos os nós até chegar ao penúltimo para depois alterar o seu prox para NULL.

Consigo por o aux apontar para o 4 , mas depois falta mete prox do 3 para NULL.

1,2,3,4

pno Retiraultimoelemento(pno lista)
{
 pno aux;
 pno novofim;

 aux=lista;

 if (lista==NULL)
 {
    printf("A lista esta vazia");
 } 
 else
 {
  while (aux->prox != NULL) // Se metesse (aux != null) o ponteiro ia apontar para depois do último
  {
	  aux=aux->prox; // Ando com o ponteiro até achar o último paciente
	  printf("\n\Estou a apontar para o paciente %s\n",aux->nome);
  }
 }
	 free(aux);
 return aux;
}

Share this post


Link to post
Share on other sites
waza

verificas se aux->prox->prox == NULL

algo do genero

if(aux->prox->prox == NULL)
 aux -> prox = NULL;

Edited by waza

Share this post


Link to post
Share on other sites
mundo

Arranjas 2 variaveis, uma que começa no inicio da lista e outra no proximo do inicio da lista e incrementas ao mesmo tempo as 2, do genero: A e a outra A->prox, quando a A->prox chegar a NULL, fazes free dessa e poes a A a apontar para NULL.

Peço desculpa da forma que me expressei mas espero ter esclarecido

Share this post


Link to post
Share on other sites
HappyHippyHippo

a solução já foi apresentada pelo @waza, mas existem casos particulares a teres em conta, e fica assim:

pno Retiraultimoelemento(pno lista)
{
 pno aux = lista;

 if (aux == NULL)
 {
   printf("A lista esta vazia");
 } 
 else
 {
   if (lista->prox == NULL)
   {
     // a lista só tem um elemento !!!
     free(lista); // <-------------------------------- tratar da libertação de memória !!! nunca esquecer !!!
     return NULL;
   }
   else
   {
     while (aux->prox->prox != NULL) // <------------- pesquisar pelo penúltimo elemento, para teres a referência do último
     {
       aux = aux->prox;
     }

     free(aux->prox); // <---------------------------- tratar da libertação de memória !!! nunca esquecer !!!
     aux->prox = NULL; // <--------------------------- limpar o "agora" lixo do ponteiro
   }
 }

 return lista; // <----------------------------------- epa .. tu retornas sempre a lista e nunca o (agora) último da lista !!
}


IRC : sim, é algo que ainda existe >> #p@p

Share this post


Link to post
Share on other sites
waza

assim consegui !

depois à variavel a que é atribuida o retorno compara-se com -1 e se for mete-se lista = NULL

case 2: i = RetiraPaciente(lista);
                   if(i == -1){
                       free(lista);
                       lista = NULL;
                   }

int RetiraPaciente(pno lista)
{
pno aux = NULL;
if(lista->prox == NULL){
		   return -1;
		}
if (lista==NULL)
{
	printf("A lista esta vazia");
	return ;
}
else
{
	while (1)
	{

		if(lista->prox->prox == NULL)
		{
			printf("Tenho o ponteiro aux apontar para o o paciente antes do ultimo %s e o ultimo paciente o que vai ser libertado e o %s", lista,lista->prox);
			aux = lista->prox->prox;
			lista->prox = NULL;
			break;  
		}
		lista = lista->prox;
	}
	free(aux);
}
return 0;
}

isto tudo porque nao removia o que restava, encontrei esta solução !

Edited by waza

Share this post


Link to post
Share on other sites
thinkabout

Boas ,

Depois da ajuda do waza já andava ali com o ponteiro o sítio correcto, mas depois nunca conseguia libertar quando só existia um elemento.

if(aux->prox->prox == NULL)
 aux -> prox = NULL;

Isto nem sequer me tinha passado pela a cabeça, não sabia que podia fazer isto.

Obrigado a todos

Share this post


Link to post
Share on other sites
HappyHippyHippo

Depois da ajuda do waza já andava ali com o ponteiro o sítio correcto, mas depois nunca conseguia libertar quando só existia um elemento.

mas viste o meu post ?


IRC : sim, é algo que ainda existe >> #p@p

Share this post


Link to post
Share on other sites
thinkabout

Yep, até compreendi das duas formas mas acho a tua maneira mais elegante.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

×
×
  • Create New...

Important Information

By using this site you accept our Terms of Use and Privacy Policy. We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.