mirror of
https://hub.njuu.cf/TheAlgorithms/C-Plus-Plus.git
synced 2023-10-11 13:05:55 +08:00
c915f9f3c2
Added bottom function for getting bottom element from a stack .
63 lines
1.5 KiB
C++
63 lines
1.5 KiB
C++
#include <iostream>
|
|
|
|
int *stack;
|
|
int stack_idx = 0, stack_size;
|
|
|
|
void push(int x) {
|
|
if (stack_idx == stack_size) {
|
|
std::cout << "\nOverflow";
|
|
} else {
|
|
stack[stack_idx++] = x;
|
|
}
|
|
}
|
|
|
|
void pop() {
|
|
if (stack_idx == 0) {
|
|
std::cout << "\nUnderflow";
|
|
} else {
|
|
std::cout << "\n" << stack[--stack_idx] << " deleted";
|
|
}
|
|
}
|
|
|
|
void show() {
|
|
for (int i = 0; i < stack_idx; i++) {
|
|
std::cout << stack[i] << "\n";
|
|
}
|
|
}
|
|
|
|
void topmost() { std::cout << "\nTopmost element: " << stack[stack_idx - 1]; }
|
|
void bottom() { std::cout << "\nBottom element: " << stack[0]; } // If we need access to first element without using pop command
|
|
int main() {
|
|
std::cout << "\nEnter stack_size of stack : ";
|
|
std::cin >> stack_size;
|
|
stack = new int[stack_size];
|
|
int ch, x;
|
|
do {
|
|
std::cout << "\n0. Exit";
|
|
std::cout << "\n1. Push";
|
|
std::cout << "\n2. Pop";
|
|
std::cout << "\n3. Print";
|
|
std::cout << "\n4. Print topmost element:";
|
|
std::cout << "\n5. Print Bottom element:";
|
|
std::cout << "\nEnter Your Choice : ";
|
|
std::cin >> ch;
|
|
if (ch == 1) {
|
|
std::cout << "\nInsert : ";
|
|
std::cin >> x;
|
|
push(x);
|
|
} else if (ch == 2) {
|
|
pop();
|
|
} else if (ch == 3) {
|
|
show();
|
|
} else if (ch == 4) {
|
|
topmost();
|
|
} else if(ch == 5) {
|
|
bottom();
|
|
}
|
|
} while (ch != 0);
|
|
|
|
delete[] stack;
|
|
|
|
return 0;
|
|
}
|