-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstack-using-array.cpp
137 lines (135 loc) · 2.61 KB
/
stack-using-array.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
/* Program to implement stack using array */
#include<iostream>
using namespace std;
class Stack
{
int cur ,capacity ,*arr;
public:
// constructor which takes capacity as argument
Stack(int capacity)
{
this->capacity = capacity;
cur = -1;
// dynamically allocating memory
arr=new int[capacity];
// if arr contain null
if(arr == NULL)
{
cout << "Memory not located";
exit(0);
}
}
~Stack()
{
delete []arr;
}
void push(int);
void pop();
int top();
int empty();
};
// function to push data into stack
void Stack::push(int data)
{
if(cur == capacity-1)
cout << "Stack is full";
else
{
cur++;
arr[cur] = data;
}
}
// function to pop data from stack
void Stack::pop()
{
cur--;
}
// function to get the top most element of the stack
int Stack::top()
{
return arr[cur];
}
// function to check whether the stack is empty of not
int Stack::empty()
{
if(cur == -1)
return 1;
else
return 0;
}
// function to clear screen
void clear_screen()
{
#ifdef _WIN32
system("cls");
#elif __unix__
system("clear");
#else
cout << "clear screen not supports";
#endif
}
//driver code
int main()
{
int cap;
int choice ,data;
cout << "Enter the size: ";
cin >> cap;
Stack s(cap);
while(1)
{
cout << "1: Push\n2: Pop\n3: Top\n4:Exit\n\nEnter your choice ";
cin >> choice;
switch(choice)
{
// push data into stack
case 1:
cout << "Enter element: ";
cin >> data;
s.push(data);
break;
case 2:
// pop data from stack
if(s.empty())
cout << "Stack is empty";
else
{
data = s.top();
s.pop();
cout << "Popped element: " << data;
}
break;
// get top element from stack
case 3:
if(!s.empty())
{
data = s.top();
cout << "Top element: "<< data;
}
else
cout << "Stack is empty";
break;
case 4:
// exit
exit(0);
default:
// run default case when none one the above case runs
cout << "Invalid choice";
}
// clear the screen
clear_screen();
}
}
/*
Input: Enter the size: 5
Push -1
Push 2
Push 3
Output:
Pop 3
Top 2
Pop 2
Pop -1
Pop Stack is empty
Time complexity: O(1) for all push,pop,top,empty
*/