Ir ao conteúdo
  • Cadastre-se

Lista em C.


Posts recomendados

Olá pessoal, estou resolvendo um programa que meu professor pediu pra gente fazer, eu consegui resolver ate o 3º, o 4º está dando um problema e não consigo resolver, alguém apito a me ajudar?

adicionado 1 minuto depois
agora, Pedro Henrique Faria Teixe disse:

Olá pessoal, estou resolvendo um programa que meu professor pediu pra gente fazer, eu consegui resolver ate o 3º, o 4º está dando um problema e não consigo resolver, alguém apito a me ajudar?

#include <stdio.h>
#include <stdlib.h>
typedef struct ListElmt_{
 int data;
 struct ListElmt_ *next;
} ListElmt;
typedef struct List_ {
 int size;
 ListElmt *head;
 ListElmt *tail;
} List;
List *list_init(){
    List *list = (List *) malloc(sizeof(List));
 list->size = 0;
 list->head = NULL;
 list->tail = NULL;
 return list;
}
void insert(List *list,int num){
    ListElmt *node = (ListElmt *) malloc(sizeof(ListElmt));
    if(list->size == 0){
        node->data = num;
        node->next = NULL;
        list->head =  node;
        list->tail = node;
    }
    else{
        node->data = num;
        node->next = NULL;
        list->tail->next = node;
        list->tail = node;
    }
    (list->size)++;
}
int  *pop(List *list){
    if(list == NULL){
        printf("Lista vazia.\n");
        return 0;
    }
    ListElmt *node = list->head;
    list->head = node->next;
    (list->size)--;
    return node->data;
    free(node);
}
ListElmt *atpos(List *list, int pos){
    if(pos>=0 && pos<=list->size){
        ListElmt *node = list->head;
        int i;
        for(i=0;i<pos;i++)
            node = node->next;

        return node;
    }
    //printf("Posicao invalida.\n");
}
int *removeatpos(List *list, int pos){
    ListElmt *current = atpos(list,pos);
    if(current!=NULL){
        ListElmt *previous = atpos(list,pos-1);
        previous->next = current->next;
        return current->data;
        free(current);
        (list->size)--;
    }
}
void progress(List *list, int i, int j){
    if(list == NULL)
    {
        printf("Lista vazia.\n");
        return;
    }
    int aux=0;
    ListElmt *node;
    for(aux = i; aux<=j; aux++){
        removeatpos(list,aux);
    }
}
void printList(List *list){
    if(list == NULL)
    {
        printf("Lista vazia.\n");
        return;
    }
    ListElmt *node = list->head;
    while(node != NULL){
        printf("%d ",node->data);
        node = node->next;
    }
}
int main(){
    List *list = list_init();
    insert(list,10);
    insert(list,20);
    insert(list,30);
    insert(list,40);
    insert(list,50);
    insert(list,60);
    insert(list,70);
//int num = pop(list);
int   pos = 3,aux;
aux = pos-1;
int i=2,j=5;


   //int num =  removeatpos(list,pos-1);
   progress(list,i-1,j-1);

    printList(list);

return 0;
}

Este e o Código e vou mandar o arquivo com o que ele pede para fazer.

 

Prova1-2017-1.pdf

Link para o comentário
Compartilhar em outros sites

Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...