Basics of Stack Data Structure

by Vibrant Publishers
Stack is an abstract, Linear Data Structure that follows the Last-In-First-Out (LIFO) principle. All data operations are done at the top of the stack which means the last item inserted is first accessible. Insertions in a stack are called “PUSH” and deletions are termed “POP”. Other abstract data types such as Array, Structure, Pointer, or Linked List are used to implement the stack.

It is most commonly used in real-world scenarios such as a stack of books or a stack of coins.

 

 

Stack Operations:

Initialize stack and de-initialize once done. To support these tasks, the stack has to implement these basic operations:

 

  • Push:
    Lets you store an item on the stack This operation checks if the stack is full and exits. If the stack is not full, add the data and increment top to point to the next empty slot.

 
This pseudo code represents the Stack push operation:

 

 

push(item)

 

{

 

  If stack is full

 

  {

 

    exit

 

  }

 

  else

 

  {

 

    top= top +1

 

    stack[top]=item

 

  }

 

}

 

  • Pop:
    Lets you access an item from the stack Pop operation checks if the stack is empty and exits for an empty stack. If the stack is not empty, we access the item at which the top is pointing. The top position is decremented by 1.

 

 

Below pseudo-code shows a simple representation of pop:

 

pop(item)

 

{

 

  If stack is empty

 

  {

 

    exit

 

  }

 

  else

 

  {

 

    item=stack[top]

 

    top= top -1

 

    return item

 

  }

 

}

 

  • Peek:
    Lets you read the top item of the stack without having to remove it

 

peek()

 

{

 

  return stack[top]

 

}

 

  • isFull:
    It returns a Boolean and checks whether the stack is full before the push operation. The pseudo-code below checks if the top is at the max. If it is, that means the stack is full.

 

bool isfull()

 

{

 

  if(top == MAXSIZE)

 

  return true;

 

  else return false;

 

}

 

  • isEmpty:
    It returns a Boolean and checks if the stack is empty before the pop operation. We sometimes use an array to implement stack and pointers to indicate top which is initialized to -1. So we check if the top is equal to -1, which means the stack is empty.

 

bool isempty(){

 

  if(top == -1)

 

  return true;

 

  else

 

  return false;

 

}

 

  • Rotate:
    Rotates the top-most items in the stack.

 

  • Swap:
    This operation lets you exchange 2 top-most items in a swap. This is most suitable for implementing sort algorithms.

 

To ace your interview, you can explore related topics. Learn about other data structures through the following blogs on our website: 

  1. The Basics of Stack Data Stucture 
  2. Trees
  3. Know your Queue Data Structures in 60 seconds
  4. Basics of hash data structures

    These provide insights into the various types of data structures and will give you better understanding.

     

    Get one step closer to your dream job!

     

    Pave the route to your dream job by preparing for your interview with questions from our Job Interview Questions Book Series These provide a comprehensive list of questions for your interview regardless of your area of expertise. These books include:
    1. HR Interview Questions You’ll Most Likely Be Asked (Third Edition) 
    2. Innovative Interview Questions You’ll Most Likely Be Asked
    3. Leadership Interview Questions You’ll Most Likely Be Asked

    You can find them on our website!