-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstack_with_link_list.cpp
204 lines (124 loc) · 2.93 KB
/
stack_with_link_list.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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
#include <iostream>
#include <climits>
using namespace std;
// Structue to store the Node Values of Link List.
struct Node {
int data; // To store the data
Node* next; // To store the pointer of the new node.
};
// Class to store all finction of the stack.
class Stack_With_Link_List {
Node* head; // Pointer to store head node.
int top; // Store the size of the stack.
public:
// Constructre to initilized value.
Stack_With_Link_List() {
head = nullptr;
top = 0;
};
/* ################### Functions start Here ################## */
// Function to add value to the stack
void push(int value) {
Node* temp = new Node; // Creating a new node.
temp->data = value; // Adding data to the temp node
temp->next = head; // Pointing temp->next to the head pointer
head = temp; // Pointing head to the temp node
top++; // Incresing the size of the stack.
}
// Function to return and remove the last element of the stack
int pop() {
Node* temp = head; // Creating a new node.
head = temp->next; // Pointing head to the 2nd node
int temp_value = temp->data; // storing the data of the 1st node
delete temp; // Deleting the first node
--top; // Reducing the size of the stack
return temp_value; // returning the value of teh first node.
}
// Finction to return the lastest value of the stack.
int peek() {
if (head != nullptr)
return head->data;
return INT_MIN;
}
// Function to check if stack is empty.
bool isEmpty() {
return (head == nullptr);
}
// Function to return size of the stack.
int size() {
return top;
}
// Function to print the stack.
void display() {
Node* temp = head;
while (temp != nullptr) {
cout << temp->data << " -> ";
temp = temp->next;
}
cout << "NULL" << endl;
}
};
// Main driver function.
int main() {
Stack_With_Link_List s;
int i = 1;
cout << "Is stack EMPTY?? ";
cout << s.isEmpty() << endl;
cout << "Stack Peek : ";
cout << s.peek() << endl;
s.push(i);
i++;
cout << "Is stack EMPTY?? ";
cout << s.isEmpty() << endl;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
s.push(i);
i++;
cout << "Stack Become : ";
s.display();
cout << "Stack Peek : ";
cout << s.peek() << endl;
cout << "Stack Size Become : ";
cout << s.size() << endl;
cout << "Is stack EMPTY?? ";
cout << s.isEmpty() << endl;
s.pop();
s.pop();
s.pop();
cout << "Stack Become : ";
s.display();
cout << "Stack Peek : ";
cout << s.peek() << endl;
cout << "Stack Size Become : ";
cout << s.size() << endl;
cout << "Is stack EMPTY?? ";
cout << s.isEmpty() << endl;
s.pop();
s.pop();
s.pop();
cout << "Stack Become : ";
s.display();
cout << "Stack Peek : ";
cout << s.peek() << endl;
cout << "Stack Size Become : ";
cout << s.size() << endl;
cout << "Is stack EMPTY?? ";
cout << s.isEmpty() << endl;
return 0;
}