KEMBAR78
Module 7 - The Stack ADT | PDF | Computing | Computer Programming
0% found this document useful (0 votes)
21 views9 pages

Module 7 - The Stack ADT

A stack is a linear data structure that operates on a Last In First Out (LIFO) principle, allowing elements to be added (push) or removed (pop) from the top. Basic operations include checking if the stack is empty or full, and peeking at the top element. The document also provides a Java implementation of a stack, demonstrating its functionality through various methods.

Uploaded by

egujosh321
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
21 views9 pages

Module 7 - The Stack ADT

A stack is a linear data structure that operates on a Last In First Out (LIFO) principle, allowing elements to be added (push) or removed (pop) from the top. Basic operations include checking if the stack is empty or full, and peeking at the top element. The document also provides a Java implementation of a stack, demonstrating its functionality through various methods.

Uploaded by

egujosh321
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 9

The Stack Data Structure

A stack is a linear data structure that follows the principle of Last In First
Out (LIFO). This means the last element inserted inside the stack is
removed first.
One can think of the stack data structure as the pile of plates on top of
another.
Here, we can:
 Put a new plate on top
 Remove the top plate
 If we want the plate at the bottom, we first have to remove all the
plates on top. This is exactly how the stack data structure works.

In programming terms, putting an item on top of the stack is called push


and removing an item is called pop.
Basic Operations of Stack
Some basic operations allow us to perform different actions on a stack.

Push: Add an element to the top of a stack


Pop: Remove an element from the top of a stack
IsEmpty: Check if the stack is empty
IsFull: Check if the stack is full
Peek: Get the value of the top element without removing it
Workings of Stack Data Structure (1)
The operations work as follows:
1. A pointer called TOP is used to keep track of the top element in
the stack.
2. When initializing the stack, we set its value to -1 so that we can
check if the stack is empty by comparing TOP == -1.
3. On pushing an element, we increase the value of TOP and place
the new element in the position pointed to by TOP.
4. On popping an element, we return the element pointed to by TOP
and reduce its value.
5. Before pushing, we check if the stack is already full
6. Before popping, we check if the stack is already empty
Workings of Stack Data Structure (2)
// Stack implementation in Java
class Stack {
private int arr[];
private int top;
private int capacity;

// Creating a stack
Stack(int size) {
arr = new int[size];
capacity = size;
top = -1;
}
// Stack implementation in Java Cont’d
// Add elements into stack
public void push(int x) {
if (isFull()) {
System.out.println("OverFlow\nProgram Terminated\n");
System.exit(1);
}
System.out.println("Inserting " + x);
arr[++top] = x;
}
// Stack implementation in Java Cont’d
// Remove element from stack
public int pop() {
if (isEmpty()) {
System.out.println("STACK EMPTY");
System.exit(1);
}
return arr[top--];
}
//Return the size of the stack
public int size() {
return top + 1;
}
// Check if the stack is empty
public Boolean isEmpty() {
return top == -1;
}
// Check if the stack is full
public Boolean isFull() {
return top == capacity - 1;
}
public void printStack() {
for (int i = 0; i <= top; i++) {
System.out.println(arr[i]);
}
}
public static void main(String[] args) {
Stack stack = new Stack(5);
stack.push(1);
stack.push(2);
stack.push(3);
stack.push(4);
stack.pop();
System.out.println("\nAfter popping out");
stack.printStack();
}
}

You might also like