-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathqueue.c
114 lines (90 loc) · 2.33 KB
/
queue.c
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include "queue.h"
#include <stdlib.h>
unsigned int indepRand()
{
FILE * F = fopen("/dev/urandom", "r");
if(!F)
{
printf("Cannot open urandom...\n");
abort();
}
unsigned int Ret;
unsigned int X = fread((char *) &Ret, 1, sizeof(unsigned int), F);
fclose(F);
return Ret;
}
struct fifo_queue* init_queue(){
struct fifo_queue* new_queue = (struct fifo_queue*)malloc(sizeof(struct fifo_queue));
new_queue->head = NULLPTR;
new_queue->tail = NULLPTR;
return new_queue;
}
void free_queue(struct fifo_queue* q){
struct queue_elem* elem = q->head;
while(get(q) >= 0);
free(q);
}
int peak_head(struct fifo_queue *q){
if(q->head == NULLPTR) return INT_MIN;
return q->head->value;
}
int get(struct fifo_queue *q){
struct queue_elem* tmp = q->head;
if(q->head == NULLPTR) return INT_MIN;
if(q->head->next_elem == NULLPTR){
q->head = NULLPTR;
q->tail = NULLPTR;
return tmp->value;
}
q->head = q->head->next_elem;
q->head->prev_elem = NULLPTR;
int val = tmp->value;
free(tmp);
return val;
}
void put(struct fifo_queue *q, int value){
struct queue_elem *elem = (struct queue_elem*)malloc(sizeof(struct queue_elem));
elem->next_elem = NULLPTR;
elem->prev_elem = NULLPTR;
elem->value = value;
if(q->head == NULLPTR){
q->head = elem;
q->tail = elem;
return;
}
q->tail->next_elem = elem;
elem->prev_elem = q->tail;
q->tail = elem;
return;
}
int count_occurences(struct fifo_queue *q, int mod){
struct queue_elem *tmp_elem = q->head;
int count = 0;
while(tmp_elem != NULLPTR){
if( tmp_elem->value % 2 == mod )
count++;
tmp_elem = tmp_elem->next_elem;
}
return count;
}
int count_size(struct fifo_queue *q){
struct queue_elem *tmp_elem = q->head;
int count = 0;
while(tmp_elem != NULLPTR){
count++;
tmp_elem = tmp_elem->next_elem;
}
return count;
}
int can_produce_even(struct fifo_queue *q){
return (count_occurences(q, 0) < 10);
}
int can_produce_odd(struct fifo_queue *q){
return (count_occurences(q, 1) < count_occurences(q, 0));
}
int can_eat_even(struct fifo_queue *q){
return (count_size(q) > 3 && peak_head(q)%2 == 0);
}
int can_eat_odd(struct fifo_queue *q){
return (count_size(q) > 7 && peak_head(q)%2 == 1);
}