-
Notifications
You must be signed in to change notification settings - Fork 1
/
stack.c
93 lines (67 loc) · 1.34 KB
/
stack.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
/*
* stack.c
* Created by: Nayef Copty
*/
#include "stack.h"
#include <stdlib.h>
#include <stdio.h>
#include <assert.h>
void stack_init(struct stack *stack) {
assert(stack != NULL);
stack->top = NULL;
}
void push(struct stack *stack, struct stack_elem *elem) {
elem->next = stack->top;
stack->top = elem;
}
struct stack_elem * pop(struct stack *stack) {
if (isEmpty(stack) == 1)
return NULL;
else {
struct stack_elem *node = stack->top;
stack->top = stack->top->next;
return node;
}
}
struct stack_elem * peek(struct stack *stack) {
if (isEmpty(stack) == 1)
return NULL;
else
return stack->top;
}
int count(struct stack *stack) {
if (isEmpty(stack) == 1)
return 0;
else {
struct stack_elem *temp;
temp = stack->top;
int count = 0;
while (temp != NULL) {
count++;
temp = temp->next;
}
return count;
}
}
int isEmpty(struct stack *stack) {
if (stack->top == NULL)
return 1;
else
return 0;
}
struct stack clear(struct stack *stack) {
if (isEmpty(stack) == 0) {
struct stack cleared_nodes;
stack_init(&cleared_nodes);
struct stack_elem *elem;
elem = stack->top;
while (elem != NULL) {
push(&cleared_nodes, elem);
elem = stack->top->next;
stack->top = NULL;
stack->top = elem;
}
stack->top = NULL;
return cleared_nodes;
}
}