Dynamic Implementation of Stack in C++

Dynamic Implementation of Stack in C++ using linked list

#include <iostream.h>
#include <conio.h>

class stack
{
    struct node
    {
        int info;
        node *next;
    }*stack;
    public:
        stack(){stack=NULL;}
        void push();
        void pop();
        void display();
};

void stack::push()
{
    int data;
    node *newnode;
    newnode=new node;
    cout<<"Enter the data"<<endl;
    cin>>data;
    newnode->info=data;
    newnode->next=stack;
    stack=newnode;
}

void stack::pop()
{
    node *temp=stack;
    if(temp==NULL) cout<<"Stack is empty"<<endl;
    else
    {
        stack=temp->next;
        cout<<"The data is:"<<temp->info;
    }
    delete temp;
}

void stack::display()
{
    int a=0;
    node *temp=stack;
    cout<<"The items in the stackare"<<endl;
    while(temp!=NULL)
    {
        a++;
        cout<<a<<"."<<temp->info<<endl;
        temp=temp->next;
    }
    if(a==0)
    {
        clrscr();
        cout<<"Stack is empty";
    }
}

void main()
{
    int ch;
    stack a;
    do
    {
        clrscr();
        cout<<"Menu"<<endl;
        cout<<"1.Push operation"<<endl;
        cout<<"2.Pop operation"<<endl;
        cout<<"3.Display"<<endl;
        cout<<"4.Exit"<<endl;
        cout<<"Enter ur choice:";
        cin>>ch;
        switch(ch)
        {
            case 1:
                a.push();
                break;
            case 2:
                a.pop();
                break;
            case 3:
                a.display();
                break;
            case 4:
                break;
            default:
                cout<<"Out of menu"<<endl;
                break;
        }
        getch();
    }while(ch!=4);

}

No comments :

Post a Comment

Your Comment and Question will help to make this blog better...