2017-12-24 01:30:49 +08:00
|
|
|
#include<iostream>
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
struct node
|
|
|
|
{
|
|
|
|
int val;
|
|
|
|
node *next;
|
|
|
|
};
|
|
|
|
|
|
|
|
node *start;
|
|
|
|
|
|
|
|
void insert(int x)
|
|
|
|
{
|
|
|
|
node *t=start;
|
|
|
|
if (start!=NULL)
|
|
|
|
{
|
|
|
|
while(t->next!=NULL)
|
|
|
|
{
|
|
|
|
t=t->next;
|
|
|
|
}
|
|
|
|
node *n= new node;
|
|
|
|
t->next=n;
|
|
|
|
n->val=x;
|
|
|
|
n->next=NULL;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
node *n= new node;
|
|
|
|
n->val=x;
|
|
|
|
n->next=NULL;
|
|
|
|
start=n;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-09 23:01:55 +08:00
|
|
|
void remove(int x){
|
|
|
|
|
|
|
|
if( start == NULL ){
|
|
|
|
cout<<"\nLinked List is empty\n";
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
else if( start->val == x ){
|
|
|
|
node *temp = start;
|
|
|
|
start = start->next;
|
|
|
|
delete temp;
|
|
|
|
return ;
|
2017-12-24 01:30:49 +08:00
|
|
|
}
|
2019-01-09 23:01:55 +08:00
|
|
|
|
|
|
|
node *temp = start, *parent = start;
|
|
|
|
|
|
|
|
while( temp != NULL && temp->val != x ){
|
|
|
|
parent = temp;
|
|
|
|
temp = temp->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
if( temp == NULL ){
|
|
|
|
cout <<endl <<x <<" not found in list\n";
|
|
|
|
return ;
|
|
|
|
}
|
|
|
|
|
|
|
|
parent->next = temp->next;
|
|
|
|
delete temp;
|
2017-12-24 01:30:49 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
void search(int x)
|
|
|
|
{
|
|
|
|
node *t= start;
|
|
|
|
int found =0;
|
|
|
|
while(t!=NULL)
|
|
|
|
{
|
|
|
|
if(t->val==x)
|
|
|
|
{
|
|
|
|
cout<<"\nFound";
|
|
|
|
found=1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
t=t->next;
|
|
|
|
}
|
|
|
|
if(found==0)
|
|
|
|
{
|
|
|
|
cout<<"\nNot Found";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void show()
|
|
|
|
{
|
|
|
|
node *t=start;
|
|
|
|
while(t!=NULL)
|
|
|
|
{
|
|
|
|
cout<<t->val<<"\t";
|
|
|
|
t=t->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
int main()
|
|
|
|
{
|
|
|
|
int choice, x;
|
|
|
|
do
|
|
|
|
{
|
|
|
|
cout<<"\n1. Insert";
|
|
|
|
cout<<"\n2. Delete";
|
|
|
|
cout<<"\n3. Search";
|
|
|
|
cout<<"\n4. Print";
|
2018-09-29 02:11:01 +08:00
|
|
|
cout<<"\n0. Exit";
|
2017-12-24 01:30:49 +08:00
|
|
|
cout<<"\n\nEnter you choice : ";
|
|
|
|
cin>>choice;
|
|
|
|
switch (choice)
|
|
|
|
{
|
|
|
|
case 1 : cout<<"\nEnter the element to be inserted : ";
|
|
|
|
cin>>x;;
|
|
|
|
insert(x); break;
|
|
|
|
case 2 : cout<<"\nEnter the element to be removed : ";
|
|
|
|
cin>>x;
|
|
|
|
remove(x); break;
|
|
|
|
case 3 : cout<<"\nEnter the element to be searched : ";
|
|
|
|
cin>>x;
|
|
|
|
search(x); break;
|
2018-09-29 02:11:01 +08:00
|
|
|
case 4 : show();
|
|
|
|
cout<<"\n"; break;
|
2017-12-24 01:30:49 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
while(choice!=0);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|