Stack
- Stack is an ordered list in which, insertion and deletion can be performed only at one end that is called top.
- Stack is a recursive data structure having pointer to its top element.
- Stacks are sometimes called as Last-In-First-Out (LIFO) lists i.e. the element which is inserted first in the stack, will be deleted last from the stack.
Applications of Stack
- Recursion
- Expression evaluations and conversions
- Parsing
- Browsers
- Editors
- Tree Traversals
Operations on Stack
There are various operations which can be performed on stack.
data:image/s3,"s3://crabby-images/d1546/d154669cabbc3fccefcc4ae00886d948d0ac8f97" alt="DS Stack Introduction"
1. Push : Adding an element onto the stack
data:image/s3,"s3://crabby-images/a1b36/a1b363be2ae8d4b192e7faf794ab5d3aae29548c" alt="DS Stack Introduction"
2. Pop : Removing an element from the stack
data:image/s3,"s3://crabby-images/09b3f/09b3f37b75352a6eb3b6e974a4e86c921fbe8d62" alt="DS Stack Introduction"
3. Peek : Look all the elements of stack without removing them.
How the stack grows?
Scenario 1 : Stack is empty
The stack is called empty if it doesn't contain any element inside it. At this stage, the value of variable top is -1.
data:image/s3,"s3://crabby-images/4ade9/4ade910527ca05dcd5d4b67641a5e99db02ecff6" alt="DS Stack Introduction"
Scenario 2 : Stack is not empty
Value of top will get increased by 1 every time when we add any element to the stack. In the following stack, After adding first element, top = 2.
data:image/s3,"s3://crabby-images/e8fb2/e8fb2515add13224313a947be18b80b6dfc80e0d" alt="DS Stack Introduction"
Scenario 3 : Deletion of an element
Value of top will get decreased by 1 whenever an element is deleted from the stack.
In the following stack, after deleting 10 from the stack, top = 1.
data:image/s3,"s3://crabby-images/12c6e/12c6e185dc428ae0df83c276a5069e31dde97476" alt="DS Stack Introduction"
Top and its value :
Top position | Status of stack |
---|---|
-1 | Empty |
0 | Only one element in the stack |
N-1 | Stack is full |
N | Overflow |