/*PROGRAM TO DELETE AN ELEMENT FROM THE END OF A CIRCULAR LINKED LIST*/
#include<conio.h>
#include<iostream.h>
struct node
{
int data;
struct node *link;
};
void main()
{
struct node *start=NULL,*ptr,*temp;
int num,item;
char ch;
clrscr();
cout<<“Inserting elements in the list:”<<endl;
do
{
temp=new node;
cout<<“Enter element: “;
cin>>num;
temp->data=num;
if(start==NULL)
{
start=temp;
start->link=start;
}
else if(start->link==start)
{
start->link=temp;
temp->link=start;
}
else
{
ptr=start;
while(ptr->link!=start)
{
ptr=ptr->link;
}
temp->link=start;
ptr->link=temp;
}
cout<<“Do you want to continue?? “;
cin>>ch;
}while(ch==’y’||ch==’Y’);
cout<<“Elements in the list are:”<<endl;
cout<<start->data<<“\t”;
for(ptr=start->link;ptr!=start;ptr=ptr->link)
{
cout<<ptr->data<<“\t”;
}
//DELETION
cout<<endl<<“Do you want to perform deletion?? “;
cin>>ch;
if(ch==’y’||ch==’Y’)
{
do
{
if(start==NULL)
{
cout<<“!!List is empty!!”<<endl;
break;
}
else if(start->link==start)
{
cout<<“Deleted element is: “<<start->data<<endl;
start=NULL;
}
else
{
ptr=start;
while(ptr->link->link!=start)
{
ptr=ptr->link;
}
cout<<“Deleted element is: “<<ptr->link->data<<endl;
ptr->link=start;
}
cout<<“Do you want to continue?? “;
cin>>ch;
}while(ch==’y’||ch==’Y’);
if(start!=NULL)
{
cout<<“Remaining elements in the list are:”<<endl;
cout<<start->data<<“\t”;
for(ptr=start->link;ptr!=start;ptr=ptr->link)
{
cout<<ptr->data<<“\t”;
}
}
}
else
{
cout<<“!!Press any key to exit!!”;
}
getch();
}