2017-07-16 10:44:01 +08:00
|
|
|
/**
|
|
|
|
* Kyler Smith, 2017
|
|
|
|
* Stack data structure implementation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// INCLUDES
|
2017-07-16 10:44:01 +08:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// MACROS: CONSTANTS
|
2017-07-16 10:44:01 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// DATA STRUCTURES
|
2020-10-01 21:34:03 +08:00
|
|
|
/**
|
|
|
|
* creating a stucture with 'data'(type:int), two pointers 'next','pre' (type: struct node) .
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
struct node
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
int data;
|
2020-05-30 04:23:24 +08:00
|
|
|
struct node *next;
|
|
|
|
struct node *pre;
|
|
|
|
} * head, *tmp;
|
2017-07-16 10:44:01 +08:00
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// GLOBAL VARIABLES
|
2017-07-16 10:44:01 +08:00
|
|
|
int count = 0;
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// FUNCTION PROTOTYPES
|
2017-07-16 10:44:01 +08:00
|
|
|
void create();
|
|
|
|
void push(int x);
|
|
|
|
int pop();
|
|
|
|
int peek();
|
|
|
|
int size();
|
|
|
|
int isEmpty();
|
|
|
|
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
2020-05-30 04:23:24 +08:00
|
|
|
// MAIN ENTRY POINT
|
2017-07-16 10:44:01 +08:00
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
int main(int argc, char const *argv[])
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
int x, y, z;
|
|
|
|
|
|
|
|
create();
|
|
|
|
push(4);
|
|
|
|
x = pop();
|
|
|
|
// 4. Count: 0. Empty: 1.
|
|
|
|
printf("%d.\t\tCount: %d.\tEmpty: %d.\n", x, size(), isEmpty());
|
|
|
|
|
|
|
|
push(1);
|
|
|
|
push(2);
|
|
|
|
push(3);
|
|
|
|
x = pop();
|
|
|
|
y = pop();
|
|
|
|
// 3, 2. Count: 1. Empty: 0;
|
|
|
|
printf("%d, %d.\t\tCount: %d.\tEmpty: %d.\n", x, y, size(), isEmpty());
|
2020-06-28 23:25:37 +08:00
|
|
|
pop(); // Empty the stack.
|
2017-07-16 10:44:01 +08:00
|
|
|
|
|
|
|
push(5);
|
|
|
|
push(6);
|
|
|
|
x = peek();
|
|
|
|
push(7);
|
|
|
|
y = pop();
|
|
|
|
push(8);
|
|
|
|
z = pop();
|
|
|
|
// 1, 6, 7, 8. Count: 2. Empty: 0.
|
|
|
|
printf("%d, %d, %d.\tCount: %d.\tEmpty: %d.\n", x, y, z, size(), isEmpty());
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
return 0;
|
2017-07-16 10:44:01 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the stack to NULL.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
void create() { head = NULL; }
|
2017-07-16 10:44:01 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Push data onto the stack.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
void push(int x)
|
|
|
|
{
|
|
|
|
if (head == NULL)
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
head = (struct node *)malloc(1 * sizeof(struct node));
|
|
|
|
head->next = NULL;
|
|
|
|
head->pre = NULL;
|
|
|
|
head->data = x;
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
tmp = (struct node *)malloc(1 * sizeof(struct node));
|
|
|
|
tmp->data = x;
|
|
|
|
tmp->next = NULL;
|
|
|
|
tmp->pre = head;
|
2019-06-08 14:03:27 +08:00
|
|
|
head->next = tmp;
|
2017-07-16 10:44:01 +08:00
|
|
|
head = tmp;
|
|
|
|
}
|
|
|
|
++count;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Pop data from the stack
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
int pop()
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
int returnData;
|
2020-05-30 04:23:24 +08:00
|
|
|
if (head == NULL)
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
printf("ERROR: Pop from empty stack.\n");
|
|
|
|
exit(1);
|
2020-05-30 04:23:24 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
returnData = head->data;
|
|
|
|
|
2020-05-30 04:23:24 +08:00
|
|
|
if (head->pre == NULL)
|
|
|
|
{
|
2019-06-08 14:03:27 +08:00
|
|
|
free(head);
|
2017-07-16 10:44:01 +08:00
|
|
|
head = NULL;
|
2019-06-08 14:03:27 +08:00
|
|
|
}
|
2020-05-30 04:23:24 +08:00
|
|
|
else
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
head = head->pre;
|
|
|
|
free(head->next);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
--count;
|
|
|
|
return returnData;
|
|
|
|
}
|
|
|
|
|
2017-07-16 10:46:31 +08:00
|
|
|
/**
|
|
|
|
* Returns the next value to be popped.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
int peek()
|
|
|
|
{
|
|
|
|
if (head != NULL)
|
2017-07-16 10:44:01 +08:00
|
|
|
return head->data;
|
2020-05-30 04:23:24 +08:00
|
|
|
else
|
|
|
|
{
|
2017-07-16 10:44:01 +08:00
|
|
|
printf("ERROR: Peeking from empty stack.");
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-16 10:46:31 +08:00
|
|
|
/**
|
|
|
|
* Returns the size of the stack.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
int size() { return count; }
|
2017-07-16 10:44:01 +08:00
|
|
|
|
2017-07-16 10:46:31 +08:00
|
|
|
/**
|
|
|
|
* Returns 1 if stack is empty, returns 0 if not empty.
|
|
|
|
*/
|
2020-05-30 04:23:24 +08:00
|
|
|
int isEmpty()
|
|
|
|
{
|
|
|
|
if (count == 0)
|
2017-07-16 10:44:01 +08:00
|
|
|
return 1;
|
|
|
|
return 0;
|
|
|
|
}
|