-
Notifications
You must be signed in to change notification settings - Fork 1
/
lista.h
38 lines (32 loc) · 1.18 KB
/
lista.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/*
* @copyright João Paulo.
* Github: https://github.com/Joao-Paulo-Silva
*/
#ifndef LISTA_H
#define LISTA_H
#include <stdlib.h>
#include <stdbool.h>
// Tipo lista armazena um endereço de um valor genérico e o próximo.
typedef struct LISTA{
void * tipoGenerico;
struct LISTA * proximo;
}Lista;
// Retorna uma lista com valor nulo.
Lista * iniciaLista();
// Alocar um nó da lista na memória.
Lista * alocaLista();
// Adiciona um novo tipo ao início da lista.
Lista * addItemLista(Lista *lista, void * endTipo);
// Remove um item da lista.
Lista * removeItemLista(Lista *lista, void * endTipo);
// Deleta todos os itens da lista liberando da memória.
void deletaLista(Lista *lista);
// Deleta todos os itens da lista e libera a memória, liberando os tipos alocados.
void deletaListaDadosAlocados(Lista *lista);
// Função length retorna a quantidade de nós da lista.
int length(Lista *lista);
// Função get() pegar o valor da posição do último a ser inserido até o primeiro.
void * get(Lista *lista, unsigned int i);
// Função get() pegar o valor da posição do primeiro a ser inserido até o último.
void * getOrdemInsercao(Lista *lista, unsigned int i);
#endif /*LISTA_H*/