TheAlgorithms-C-Plus-Plus/Queue Using Linked List.cpp

91 lines
884 B
C++
Raw Normal View History

2016-08-09 18:20:07 +08:00
#include<iostream>
using namespace std;
struct node
{
int val;
node *next;
};
node *front, *rear;
2016-08-09 19:10:41 +08:00
void Enque(int x)
2016-08-09 18:20:07 +08:00
{
if (rear==NULL)
{
node *n= new node;
n->val=x;
n->next=NULL;
rear=n;
front=n;
}
else
{
node *n = new node;
n->val=x;
n->next=NULL;
rear->next=n;
rear=n;
}
}
2016-08-09 19:10:41 +08:00
void Deque()
2016-08-09 18:20:07 +08:00
{
if (rear==front)
{
cout<<"\nUnderflow";
}
else
{
node *t = front;
cout<<"\n"<<t->val<<" deleted";
front=front->next;
delete t;
}
}
void show()
{
node *t=front;
while(t!=NULL)
{
cout<<t->val<<"\t";
t=t->next;
}
}
int main()
{
int ch, x;
do
{
2016-08-09 19:10:41 +08:00
cout<<"\n1. Enque";
cout<<"\n2. Deque";
2016-08-09 18:20:07 +08:00
cout<<"\n3. Print";
cout<<"\nEnter Your Choice : ";
cin>>ch;
if (ch==1)
{
cout<<"\nInsert : ";
cin>>x;
2016-08-09 19:10:41 +08:00
Enque(x);
2016-08-09 18:20:07 +08:00
}
else if (ch==2)
{
2016-08-09 19:10:41 +08:00
Deque();
2016-08-09 18:20:07 +08:00
}
else if (ch==3)
{
show();
}
}
while(ch!=0);
return 0;
}