Open In App

Stack using Array

Last Updated : 13 Sep, 2025
Comments
Improve
Suggest changes
Like Article
Like
Report

A stack is a linear data structure that follows the Last-In-First-Out (LIFO) principle. It can be implemented using an array by treating the end of the array as the top of the stack.

Declaration of Stack using Array

A stack can be implemented using an array where we maintain:

  • An integer array to store elements.
  • A variable capacity to represent the maximum size of the stack.
  • A variable top to track the index of the top element. Initially, top = -1 to indicate an empty stack.
C++
class myStack {
    
    // array to store elements
    int *arr;       
    
    // maximum size of stack
    int capacity;   
    
    // index of top element
    int top;          

public:
    
    // constructor
    myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }
};
Java
class myStack {

    // array to store elements
    private int[] arr;

    // maximum size of stack
    private int capacity;

    // index of top element
    private int top;

    // constructor
    public myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }
}
Python
class myStack:

    def __init__(self, cap):
        
        # array to store elements
        self.arr = [0] * cap
        
        # maximum size of stack
        self.capacity = cap
        
        # index of top element
        self.top = -1
C#
class myStack {

    // array to store elements
    private int[] arr;

    // maximum size of stack
    private int capacity;

    // index of top element
    private int top;

    // constructor
    public myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }
}
JavaScript
class myStack {

    // constructor
    constructor(cap) {
        
        // array to store elements
        this.arr = new Array(cap);
        
        // maximum size of stack
        this.capacity = cap;
        
        // index of top element
        this.top = -1;
    }
}

Operations On Stack

Push Operation:

Adds an item to the stack. If the stack is full, then it is said to be an Overflow condition.

  • Before pushing the element to the stack, we check if the stack is full.
  • If the stack is full (top == capacity-1) , then Stack Overflows and we cannot insert the element to the stack.
  • Otherwise, we increment the value of top by 1 (top = top + 1) and the new value is inserted at top position .
  • The elements can be pushed into the stack till we reach the capacity of the stack.


C++
void push(int x) {
   
    if (top == capacity - 1) {
        cout << "Stack Overflow\n";
        return;
    }
   
    arr[++top] = x;
}
Java
void push(int x) {
   
    if (top == capacity - 1) {
        System.out.println("Stack Overflow");
        return;
    }
   
    arr[++top] = x;
}
Python
def push(self, x):
    
    if self.top == self.capacity - 1:
        print("Stack Overflow")
        return
    
    self.top += 1
    
    self.arr[self.top] = x
C#
void push(int x) {
  
    if (top == capacity - 1) {
        Console.WriteLine("Stack Overflow");
        return;
    }
  
    arr[++top] = x;
}
JavaScript
function push(x) {
    
    if (top === capacity - 1) {
        console.log('Stack Overflow');
        return;
    }
    
    arr[++top] = x;
}

Time Complexity: O(1)
Auxiliary Space: O(1)

Pop Operation:

Removes an item from the stack. The items are popped in the reversed order in which they are pushed. If the stack is empty, then it is said to be an Underflow condition.

  • Before popping the element from the stack, we check if the stack is empty .
  • If the stack is empty (top == -1), then Stack Underflows and we cannot remove any element from the stack.
  • Otherwise, we store the value at top, decrement the value of top by 1 (top = top – 1) and return the stored top value.


C++
int pop() {

    if (top == -1) {
        cout << "Stack Underflow\n";
        return -1;
    }

    return arr[top--];
}
Java
int pop() {
    
    if (top == -1) {
        System.out.println("Stack Underflow");
        return -1;
    }
    
    return arr[top--];
}
Python
def pop(self):
    
    if self.top == -1:
        print("Stack Underflow")
        return -1
    
    value = self.arr[self.top]
    self.top -= 1
 
    return value
C#
int pop() {
   
    if (top == -1) {
        Console.WriteLine("Stack Underflow");
        return -1;
    }
   
    return arr[top--];
}
JavaScript
function pop() {
   
    if (top == -1) {
        console.log('Stack Underflow');
        return -1;
    }
   
    return arr[top--];
}

Time Complexity: O(1)
Auxiliary Space: O(1)

Top or Peek Operation in Stack:

Returns the top element of the stack.

  • Before returning the top element from the stack, we check if the stack is empty.
  • If the stack is empty (top == -1), we simply print “Stack is empty”.
  • Otherwise, we return the element stored at index = top.
push_element_2_into_stack


C++
int peek() {
    
    if (top == -1) {
        cout << "Stack is Empty\n";
        return -1;
    }
    
    return arr[top];
}
Java
int peek() {
   
    if (top == -1) {
        System.out.println("Stack is Empty");
        return -1;
    }
   
    return arr[top];
}
Python
def peek(self):
  
    if self.top == -1:
        print("Stack is Empty")
        return -1
  
    return self.arr[self.top]
C#
int peek() {
  
    if (top == -1) {
        Console.WriteLine("Stack is Empty");
        return -1;
    }
  
    return arr[top];
}
JavaScript
function peek() {
 
    if (top == -1) {
        console.log('Stack is Empty');
        return -1;
    }
 
    return arr[top];
}

Time Complexity: O(1)
Auxiliary Space: O(1)

isEmpty Operation in Stack:

Returns true if the stack is empty, else false.

  • Check for the value of top in stack.
  • If (top == -1) , then the stack is empty so return true.
  • Otherwise, the stack is not empty so return false.
empty_stack_popping_an_element_will_cause_underflow_
C++
bool isEmpty() {
 
    return top == -1;
}
Java
boolean isEmpty() {
   
    return top == -1;
}
Python
def isEmpty(self):
   
    return self.top == -1
C#
bool isEmpty() {
    return top == -1;
}
JavaScript
isEmpty() {
    
    return this.top === -1;
}

Time Complexity: O(1)
Auxiliary Space: O(1)

isFull Operation in Stack :

Returns true if the stack is full, else false.

  • Check for the value of top in stack.
  • If (top == capacity-1), then the stack is full so return true.
  • Otherwise, the stack is not full so return false.
initial_stack
C++
bool isFull() {
  
    return top == capacity - 1;
}
Java
boolean isFull() {

  return top == capacity - 1;
}
Python
def isFull(self):
    return self.top == self.capacity - 1
C#
bool IsFull() {

  return top == capacity - 1;
}
JavaScript
function isFull() {

  return top === capacity - 1;
}

Time Complexity: O(1)
Auxiliary Space: O(1)

Full Implementation of Stack using Array

C++
#include <iostream>
using namespace std;

class myStack {
    
    // array to store elements
    int *arr;       
    
    // maximum size of stack
    int capacity;   
    
    // index of top element
    int top;        

public:

    // constructor
    myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }

    // push operation
    void push(int x) {
        if (top == capacity - 1) {
            cout << "Stack Overflow\n";
            return;
        }
        arr[++top] = x;
    }

    // pop operation
    int pop() {
        if (top == -1) {
            cout << "Stack Underflow\n";
            return -1;
        }
        return arr[top--];
    }

    // peek (or top) operation
    int peek() {
        if (top == -1) {
            cout << "Stack is Empty\n";
            return -1;
        }
        return arr[top];
    }

    // check if stack is empty
    bool isEmpty() {
        return top == -1;
    }

    // check if stack is full
    bool isFull() {
        return top == capacity - 1;
    }
};

int main() {
    myStack st(4);

    // pushing elements
    st.push(1);
    st.push(2);
    st.push(3);
    st.push(4);

    // popping one element
    cout << "Popped: " << st.pop() << "\n";

    // checking top element
    cout << "Top element: " << st.peek() << "\n";

    // checking if stack is empty
    cout << "Is stack empty: " << (st.isEmpty() ? "Yes" : "No") << "\n";

    // checking if stack is full
    cout << "Is stack full: " << (st.isFull() ? "Yes" : "No") << "\n";

    return 0;
}
Java
import java.util.Arrays;

class myStack {

    // array to store elements
    private int[] arr;

    // maximum size of stack
    private int capacity;

    // index of top element
    private int top;

    // constructor
    public myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }

    // push operation
    public void push(int x) {
        if (top == capacity - 1) {
            System.out.println("Stack Overflow");
            return;
        }
        arr[++top] = x;
    }

    // pop operation
    public int pop() {
        if (top == -1) {
            System.out.println("Stack Underflow");
            return -1;
        }
        return arr[top--];
    }

    // peek (or top) operation
    public int peek() {
        if (top == -1) {
            System.out.println("Stack is Empty");
            return -1;
        }
        return arr[top];
    }

    // check if stack is empty
    public boolean isEmpty() {
        return top == -1;
    }

    // check if stack is full
    public boolean isFull() {
        return top == capacity - 1;
    }
}

public class Main {
    public static void main(String[] args) {
        myStack st = new myStack(4);

        // pushing elements
        st.push(1);
        st.push(2);
        st.push(3);
        st.push(4);

        // popping one element
        System.out.println("Popped: " + st.pop());

        // checking top element
        System.out.println("Top element: " + st.peek());

        // checking if stack is empty
        System.out.println("Is stack empty: " +
                            (st.isEmpty() ? "Yes" : "No"));

        // checking if stack is full
        System.out.println("Is stack full: " +
                            (st.isFull() ? "Yes" : "No"));
    }
}
Python
class myStack:
    # constructor
    def __init__(self, cap):
        self.capacity = cap
        self.arr = [0] * self.capacity
        self.top = -1

    # push operation
    def push(self, x):
        if self.top == self.capacity - 1:
            print("Stack Overflow")
            return
        self.top += 1
        self.arr[self.top] = x

    # pop operation
    def pop(self):
        if self.top == -1:
            print("Stack Underflow")
            return -1
        val = self.arr[self.top]
        self.top -= 1
        return val

    # peek (or top) operation
    def peek(self):
        if self.top == -1:
            print("Stack is Empty")
            return -1
        return self.arr[self.top]

    # check if stack is empty
    def isEmpty(self):
        return self.top == -1

    # check if stack is full
    def isFull(self):
        return self.top == self.capacity - 1


if __name__ == "__main__":
    st = myStack(4)

    # pushing elements
    st.push(1)
    st.push(2)
    st.push(3)
    st.push(4)

    # popping one element
    print("Popped:", st.pop())

    # checking top element
    print("Top element:", st.peek())

    # checking if stack is empty
    print("Is stack empty: ", "Yes" if st.isEmpty() else "No")

    # checking if stack is full
    print("Is stack full: ", "Yes" if st.isFull() else "No")
C#
using System;

class myStack {

    // array to store elements
    private int[] arr;

    // maximum size of stack
    private int capacity;

    // index of top element
    private int top;

    public myStack(int cap) {
        capacity = cap;
        arr = new int[capacity];
        top = -1;
    }

    // push operation
    public void push(int x) {
        if (top == capacity - 1) {
            Console.WriteLine("Stack Overflow");
            return;
        }
        arr[++top] = x;
    }

    // pop operation
    public int pop() {
        if (top == -1) {
            Console.WriteLine("Stack Underflow");
            return -1;
        }
        return arr[top--];
    }

    // peek (or top) operation
    public int peek() {
        if (top == -1) {
            Console.WriteLine("Stack is Empty");
            return -1;
        }
        return arr[top];
    }

    // check if stack is empty
    public bool isEmpty() {
        return top == -1;
    }

    // check if stack is full
    public bool isFull() {
        return top == capacity - 1;
    }
}

class GfG {
    static void Main() {
        myStack st = new myStack(4);

        // pushing elements
        st.push(1);
        st.push(2);
        st.push(3);
        st.push(4);

        // popping one element
        Console.WriteLine("Popped:" + st.pop());

        // checking top element
        Console.WriteLine("Top element:" + st.peek());

        // checking if stack is empty
        Console.WriteLine("Is stack empty:" + (st.isEmpty() ? "Yes" : "No"));

        // checking if stack is full
        Console.WriteLine("Is stack full:" + (st.isFull() ? "Yes" : "No"));
    }
}
JavaScript
class myStack {
    constructor(cap) {
        
        // array to store elements
        this.arr = new Array(cap); 
        
        // maximum size of stack
        this.capacity = cap;       
        
        // index of top element
        this.top = -1;             
    }

    // push operation
    push(x) {
        if (this.top === this.capacity - 1) {
            console.log("Stack Overflow");
            return;
        }
        this.arr[++this.top] = x;
    }

    // pop operation
    pop() {
        if (this.top === -1) {
            console.log("Stack Underflow");
            return -1;
        }
        return this.arr[this.top--];
    }

    // peek (or top) operation
    peek() {
        if (this.top === -1) {
            console.log("Stack is Empty");
            return -1;
        }
        return this.arr[this.top];
    }

    // check if stack is empty
    isEmpty() {
        return this.top === -1;
    }

    // check if stack is full
    isFull() {
        return this.top === this.capacity - 1;
    }
}

// Driver Code
let st = new myStack(4);

// pushing elements
st.push(1);
st.push(2);
st.push(3);
st.push(4);

// popping one element
console.log("Popped: " + st.pop());

// checking top element
console.log("Top element: " + st.peek());

// checking if stack is empty
console.log("Is stack empty: " + (st.isEmpty() ? "Yes" : "No"));

// checking if stack is full
console.log("Is stack full: " + (st.isFull() ? "Yes" : "No"));

Output
Popped: 4
Top element: 3
Is stack empty: No
Is stack full: No

Stack Implementation using Dynamic Array

When using a fixed-size array, the stack has a maximum capacity that cannot grow beyond its initial size. To overcome this limitation, we can use dynamic arrays. Dynamic arrays automatically resize themselves as elements are added or removed, which makes the stack more flexible.

  • In C++, we can use vector.
  • In Java, we can use ArrayList.
  • In Python, we can use list.
  • In C#, we can use List.
  • In JavaScript, we can use Array.
C++
#include <iostream>
#include <vector>
using namespace std;

class myStack {
    vector<int> arr;

public:

    // push operation
    void push(int x) {
        arr.push_back(x);
    }

    // pop operation
    int pop() {
        if (arr.empty()) {
            cout << "Stack Underflow" << endl;
            return -1;
        }
        int val = arr.back();
        arr.pop_back();
        return val;
    }

    // peek operation
    int peek() {
        if (arr.empty()) {
            cout << "Stack is Empty" << endl;
            return -1;
        }
        return arr.back();
    }

    // check if stack is empty
    bool isEmpty() {
        return arr.empty();
    }
    
    // current size
    int size() {
        return arr.size();
    }
};

int main() {
    myStack st;

    // pushing elements
    st.push(1);
    st.push(2);
    st.push(3);
    st.push(4);

    // popping one element
    cout << "Popped: " << st.pop() << endl;

    // checking top element
    cout << "Top element: " << st.peek() << endl;

    // checking if stack is empty
    cout << "Is stack empty: " << (st.isEmpty() ? "Yes" : "No") << endl;
    
    // checking current size
    cout << "Current size: " << st.size() << endl;
}
Java
import java.util.ArrayList;

class myStack {
    ArrayList<Integer> arr = new ArrayList<>();

    // push operation
    void push(int x) {
        arr.add(x);
    }

    // pop operation
    int pop() {
        if (arr.isEmpty()) {
            System.out.println("Stack Underflow");
            return -1;
        }
        int val = arr.get(arr.size() - 1);
        arr.remove(arr.size() - 1);
        return val;
    }

    // peek operation
    int peek() {
        if (arr.isEmpty()) {
            System.out.println("Stack is Empty");
            return -1;
        }
        return arr.get(arr.size() - 1);
    }

    // check if stack is empty
    boolean isEmpty() {
        return arr.isEmpty();
    }

    // current size
    int size() {
        return arr.size();
    }

    public static void main(String[] args) {
        myStack st = new myStack();

        // pushing elements
        st.push(1);
        st.push(2);
        st.push(3);
        st.push(4);

        // popping one element
        System.out.println("Popped: " + st.pop());

        // checking top element
        System.out.println("Top element: " + st.peek());

        // checking if stack is empty
        System.out.println("Is stack empty: " + 
                            (st.isEmpty() ? "Yes" : "No"));

        // checking current size
        System.out.println("Current size: " + st.size());
    }
}
Python
class myStack:
    def __init__(self):
        self.arr = []

    # push operation
    def push(self, x):
        self.arr.append(x)

    # pop operation
    def pop(self):
        if not self.arr:
            print("Stack Underflow")
            return -1
        return self.arr.pop()

    # peek operation
    def peek(self):
        if not self.arr:
            print("Stack is Empty")
            return -1
        return self.arr[-1]

    # check if stack is empty
    def isEmpty(self):
        return len(self.arr) == 0

    # current size
    def size(self):
        return len(self.arr)


if __name__ == "__main__":
    st = myStack()

    # pushing elements
    st.push(1)
    st.push(2)
    st.push(3)
    st.push(4)

    # popping one element
    print("Popped:", st.pop())

    # checking top element
    print("Top element:", st.peek())

    # checking if stack is empty
    print("Is stack empty:", "Yes" if st.isEmpty() else "No")

    # checking current size
    print("Current size:", st.size())
C#
using System;
using System.Collections.Generic;

class myStack {
    List<int> arr = new List<int>();

    // push operation
    public void push(int x) {
        arr.Add(x);
    }

    // pop operation
    public int pop() {
        if (arr.Count == 0) {
            Console.WriteLine("Stack Underflow");
            return -1;
        }
        int val = arr[arr.Count - 1];
        arr.RemoveAt(arr.Count - 1);
        return val;
    }

    // peek operation
    public int peek() {
        if (arr.Count == 0) {
            Console.WriteLine("Stack is Empty");
            return -1;
        }
        return arr[arr.Count - 1];
    }

    // check if stack is empty
    public bool isEmpty() {
        return arr.Count == 0;
    }

    // current size
    public int size() {
        return arr.Count;
    }

    public static void Main() {
        myStack st = new myStack();

        // pushing elements
        st.push(1);
        st.push(2);
        st.push(3);
        st.push(4);

        // popping one element
        Console.WriteLine("Popped: " + st.pop());

        // checking top element
        Console.WriteLine("Top element: " + st.peek());

        // checking if stack is empty
        Console.WriteLine("Is stack empty: " + 
                            (st.isEmpty() ? "Yes" : "No"));

        // checking current size
        Console.WriteLine("Current size: " + st.size());
    }
}
JavaScript
class myStack {
    constructor() {
        this.arr = [];
    }

    // push operation
    push(x) {
        this.arr.push(x);
    }

    // pop operation
    pop() {
        if (this.arr.length === 0) {
            console.log("Stack Underflow");
            return -1;
        }
        return this.arr.pop();
    }

    // peek operation
    peek() {
        if (this.arr.length === 0) {
            console.log("Stack is Empty");
            return -1;
        }
        return this.arr[this.arr.length - 1];
    }

    // check if stack is empty
    isEmpty() {
        return this.arr.length === 0;
    }

    // current size
    size() {
        return this.arr.length;
    }
}

// Driver Code
let st = new myStack();

// pushing elements
st.push(1);
st.push(2);
st.push(3);
st.push(4);

// popping one element
console.log("Popped:", st.pop());

// checking top element
console.log("Top element:", st.peek());

// checking if stack is empty
console.log("Is stack empty:", st.isEmpty() ? "Yes" : "No");

// checking current size
console.log("Current size:", st.size());

Output
Popped: 4
Top element: 3
Is stack empty: No
Current size: 3

Fixed Size Stack Vs Dynamic Size Stack

Comparison_-Fixed-Size-Stack-vs-Dynamic-Size-Stack

Array Implementation of Stack in C++
Visit Course explore course icon
Video Thumbnail

Array Implementation of Stack in C++

Video Thumbnail

Array Implementation of Stack in Java

Explore