sorted linked
list latest
//insert as first
elt
//insert before
first elt
//inserting at
middle
//inserting at
last
//deleting the
given node first,middle,last
#include<stdio.h>
#include<malloc.h>
struct node
{
int data;
struct node *next;
};
typedef struct node
node;
node *start=NULL;
void insert(int d)
{
node *newnode=(node
*)malloc(sizeof( node));
newnode->data=d;
newnode->next=NULL;
//insert as first
elt
if(start==NULL)
{
//start->next=newnode;
start=newnode;
}
//insert before
first elt
if(newnode->data
< start->data)
{
newnode->next=start;
start=newnode;
return;
}
//inserting at
middle
node* prev; node
*ptr;
for(prev=start,ptr=start->next;ptr;prev=ptr,ptr=prev->next)
{
if(newnode->data
< ptr->data)
{
prev->next=newnode;
newnode->next=ptr;
return;
}
}
//inserting at last
if(ptr==NULL)
{
prev->next=newnode;
newnode->next=NULL;//must
return;
}
}
void display()
{
node *ptr=start;
while(ptr!=NULL)
{
printf("%d
",ptr->data);
ptr=ptr->next;//must
else infinite loop
}
printf("\n");
}
//deleting the given
node
void deleteNode()
{
int key;
printf("Enter
elt to delete:\n");
scanf("%d",&key);
//deleting the first
node
if(key==start->data)
{
node *temp;
temp=start;
start=start->next;
free(temp);
return;
}
//deleting middle
node
node *ptr; node
*prev;
for(prev=start,ptr=start->next;ptr;prev=ptr,ptr=prev->next)
{
if(ptr->data==key)
{
prev->next=ptr->next;
free( ptr);
return;
}
}
//deleteing last elt
if(ptr==NULL)
{
printf("Ket not
present in the LL.\n");
return;
}
if(start==NULL)
{
printf("No elt
to del in the LL.\n");
return;
}
}
int main()
{
insert(10);
insert(4);
insert(8);
insert(9);
insert(6);
insert(7);
insert(25);
display();
deleteNode();
display();
deleteNode();
display();
deleteNode();
display();
return 0;
}
/*
4 6 7 8 9 10 25
Enter elt to delete:
7
4 6 8 9 10 25
Enter elt to delete:
4
6 8 9 10 25
Enter elt to delete:
25
6 8 9 10*/
No comments:
Post a Comment