-
Notifications
You must be signed in to change notification settings - Fork 0
/
josephus.h
50 lines (37 loc) · 985 Bytes
/
josephus.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
39
40
41
42
43
44
45
46
47
48
49
50
#ifndef JOSEPHUS_H_
#define JOSEPHUS_H_
#include <stdbool.h>
/**
* Tipo opaco para pessoa
* - id (int)
* - isOut (bool)
*/
typedef struct pessoa Pessoa;
typedef struct celula Celula;
typedef struct lista Lista;
/**
* Inicializa uma lista circular para representar quem está na mesa
* @return Retorna um ponteiro para uma lista circular
*/
Lista *JOSEPHUS_init();
Pessoa *Inicializa_Pessoa(int id, bool isOut);
/**
* Exibe na tela todos as pessoas do array
* @param l Lista a ser exibida
*/
void JOSEPHUS_showAll(Lista *l);
/**
* Insere uma pessoa na lista
* @param pessoa Representa uma pessoa da mesa
* @param l Representa a lista circula (ou seja, a mesa)
*/
void JOSEPHUS_insert(Pessoa *pessoa, int size, Lista *l);
/**
* Libera o espaço alocado para o vetor de bool
* @param size Tamanho do array
*/
void JOSEPHUS_free(Lista *l);
void JOSEPHUS_eliminate(int M, Lista *l);
Pessoa *Inicializa_Array_Pessoas(int size);
void Libera_Pessoas(Pessoa *p);
#endif