2017-07-16 12:00:51 +08:00
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// INCLUDES
|
2017-07-16 12:00:51 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// MACROS: CONSTANTS
|
2017-07-16 12:00:51 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// DATA STRUCTURES
|
2020-10-02 01:19:55 +08:00
|
|
|
/**
|
|
|
|
* Defining the structure of the node which contains 'data' (type : integer), two pointers 'next' and 'pre' (type : struct node).
|
|
|
|
*/
|
|
|
|
struct node
|
2020-05-30 04:23:24 +08:00
|
|
|
{
|
2017-07-16 12:00:51 +08:00
|
|
|
int data;
|
2020-05-30 04:23:24 +08:00
|
|
|
struct node *next;
|
|
|
|
struct node *pre;
|
|
|
|
} * head, *tail, *tmp;
|
2017-07-16 12:00:51 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// GLOBAL VARIABLES
|
2017-07-16 12:00:51 +08:00
|
|
|
int count;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// FORWARD DECLARATIONS
|
2017-07-16 12:00:51 +08:00
|
|
|
void create();
|
|
|
|
void enque(int x);
|
|
|
|
int deque();
|
|
|
|
int peek();
|
|
|
|
int size();
|
|
|
|
int isEmpty();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// MAIN ENTRY POINT
|
2017-07-16 12:00:51 +08:00
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
int main(int argc, char const *argv[])
|
|
|
|
{
|
2017-07-16 12:00:51 +08:00
|
|
|
create();
|
|
|
|
enque(5);
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
return 0;
|
2017-07-16 12:00:51 +08:00
|
|
|
}
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
void create()
|
|
|
|
{
|
2017-07-16 12:00:51 +08:00
|
|
|
head = NULL;
|
|
|
|
tail = NULL;
|
|
|
|
}
|
|
|
|
|
2017-07-18 09:37:58 +08:00
|
|
|
/**
|
|
|
|
* Puts an item into the Queue.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
void enque(int x)
|
|
|
|
{
|
|
|
|
if (head == NULL)
|
|
|
|
{
|
2020-10-01 22:28:19 +08:00
|
|
|
head = (struct node *)malloc(sizeof(struct node));
|
2017-07-16 12:00:51 +08:00
|
|
|
head->data = x;
|
|
|
|
head->pre = NULL;
|
|
|
|
tail = head;
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2020-10-01 22:28:19 +08:00
|
|
|
tmp = (struct node *)malloc(sizeof(struct node));
|
2017-07-16 12:00:51 +08:00
|
|
|
tmp->data = x;
|
|
|
|
tmp->next = tail;
|
|
|
|
tail = tmp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-18 10:13:45 +08:00
|
|
|
/**
|
|
|
|
* Takes the next item from the Queue.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
int deque()
|
|
|
|
{
|
2020-04-21 18:38:03 +08:00
|
|
|
int returnData = 0;
|
2020-05-30 04:23:24 +08:00
|
|
|
if (head == NULL)
|
|
|
|
{
|
2017-07-16 12:00:51 +08:00
|
|
|
printf("ERROR: Deque from empty queue.\n");
|
|
|
|
exit(1);
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-07-16 12:00:51 +08:00
|
|
|
returnData = head->data;
|
2020-05-30 04:23:24 +08:00
|
|
|
if (head->pre == NULL)
|
2017-07-16 12:00:51 +08:00
|
|
|
head = NULL;
|
|
|
|
else
|
|
|
|
head = head->pre;
|
|
|
|
head->next = NULL;
|
|
|
|
}
|
2020-05-30 04:23:24 +08:00
|
|
|
return returnData;
|
2017-07-16 12:00:51 +08:00
|
|
|
}
|
2017-07-18 10:13:45 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the size of the Queue.
|
|
|
|
*/
|
2020-10-01 22:28:19 +08:00
|
|
|
int size() { return count; }
|