Ir para conteúdo
Fórum Script Brasil
  • 0

Fila Encadeada


samuelhgb

Pergunta

Boa Tarde galera, estou fazendo um exercício e nele pede para adicionar um elemento de forma ordenada em uma fila encadeada, o problema e que a fila encadeada só retira elemento do início e adiciona no final. EX: {1,2,3,5,7} item = 4 então ficaria assim {1,2,3,4,5,7}.

#include <assert.h> /**< Necessário para uso da macro "assert" */
#include <cstdlib> /**< Necessário para uso do NULL */
#include "filaenc.hpp"

struct Noh {
	int item; /**< Representa a informação a ser armazenada em cada nó da fila. */
	Noh* prox; /**< É um ponteiro para o próximo nó da fila. */
};

struct FilaEnc {
    Noh* inicio; /**< É um ponteiro para o início da fila. */
    Noh* fim; /**< É um ponteiro para o fim da fila. */
};

FilaEnc* criar_fila() {
	/* 
	 * Caso não seja possível alocar o espaço solicitado, o próprio operador "new"
	 * irá lançar uma exceção abortando a execução do programa.
	 */
	FilaEnc* fila = new FilaEnc;
    
	fila->inicio = NULL;
	fila->fim = NULL;
	return fila;
}

void liberar_fila(FilaEnc* fila) {
	/* 
	 * Macro da biblioteca \file assert.h. Aborta a execução do programa e envia uma mensagem 
	 * de erro para a saída de erro padrão, caso a expressão entre parênteses seja avaliada 
	 * como false.
	*/
	assert(fila != NULL);
	
	// Libera a memória alocada para cada nó da fila individualmente.
	while(fila->inicio != NULL) {
		remover(fila);
	}	
	delete fila;
}

bool estah_vazia(FilaEnc* fila) {
	assert(fila != NULL);	
	
	return (fila->inicio == NULL);
}

void inserir(FilaEnc* fila, int item) {
	assert(fila != NULL);
	
	Noh *novo_noh = new Noh;
	novo_noh->item = item;
	novo_noh->prox = NULL;
	
    if (fila->fim == NULL) {
        fila->inicio = novo_noh;
    } else {
        fila->fim->prox = novo_noh;
    } 
    fila->fim = novo_noh;
}

int remover(FilaEnc* fila) {
	assert(fila != NULL);
	assert(!estah_vazia(fila));    
        
	Noh* aux = fila->inicio;
    fila->inicio = aux->prox;
    int item = aux->item;
    if (fila->inicio == NULL) {
		fila->fim = NULL;
	}
    delete aux;
    return item;
}

int obter_inicio(FilaEnc* fila) {
	assert(fila != NULL);
	assert(!estah_vazia(fila));    
    
	return fila->inicio->item;
}

acima o código da fila encadeada, preciso criar uma função que insira no meio porem não tenho ideia de como fazer. Será que eu devo remover da fila adicionar em um vetor e depois de inserir o elemento do vetor volto a inserir o vetor na fila?

Link para o comentário
Compartilhar em outros sites

0 respostass a esta questão

Posts Recomendados

Até agora não há respostas para essa pergunta

Participe da discussão

Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.

Visitante
Responder esta pergunta...

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emoticons são permitidos.

×   Seu link foi incorporado automaticamente.   Exibir como um link em vez disso

×   Seu conteúdo anterior foi restaurado.   Limpar Editor

×   Você não pode colar imagens diretamente. Carregar ou inserir imagens do URL.



  • Estatísticas dos Fóruns

    • Tópicos
      152,3k
    • Posts
      652,5k
×
×
  • Criar Novo...