-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathStack.cpp
97 lines (87 loc) · 1.77 KB
/
Stack.cpp
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
#include "Stack.h"
template<typename T>
bool Stack<T>::Resize(int _capacity){
capacity = _capacity;
T* newStack = (T*)realloc(stack, sizeof(T) * capacity);
if(!newStack){
//Error
return false;
}
stack = newStack;
return true;
}
template<typename T>
Stack<T>::Stack() : capacity(DEFAULT_CAPACITY), size(0) {
stack = (T*)malloc(sizeof(T) * capacity);
if(!stack){
//Error
}
}
template<typename T>
Stack<T>::Stack(int _capacity) : capacity(_capacity), size(0) {
stack = (T*)malloc(sizeof(T) * capacity);
if(!stack){
//Error
}
}
template<typename T>
Stack<T>::Stack(const Stack<T> & s){
//construct
capacity = s.capacity;
size = s.size;
stack = (T*)malloc(sizeof(T) * capacity);
if(!stack){
//Error
}
//copy
for(int i = 0; i < size; i++)
stack[i] = s.stack[i];
}
template<typename T>
Stack<T>::~Stack(){
free(stack);
stack = nullptr;
}
template<typename T>
void Stack<T>::PushBack(T val){
stack[size++] = val;
if(size == capacity){
bool res = Resize(capacity * 2);
if(!res){
//Resize Error
}
}
}
template<typename T>
T Stack<T>::PopBack(){
if(size == 0){
//Tries to pop from an empty stack
//throw an error?
T emptyT;
return emptyT;
}
else{
T res = stack[--size];
return res;
}
}
template<typename T>
T Stack<T>::TopElement(){
if(size == 0){
//Tries to get an element from an empty stack
//throw an error?
T emptyT;
return emptyT;
}
else{
return stack[size - 1];
}
}
template<typename T>
int Stack<T>::Size(){
return size;
}
template<typename T>
bool Stack<T>::IsEmpty(){
return size == 0;
}