Monday, 2 April 2012

Program : Grounded Header Linked List – Create – Insertion


Program : Grounded Header Linked List – Create – Insertion

// Insertion in  grounded Header Linked List

#include<stdio.h>
#include<conio.h>
#include<stdlib.h>

struct link
{
          int no;
          struct link *next;
};

struct link *node,*start,*pre,*new1;
int i=0;

void create_link(struct link *node);
void display(struct link *node);
void insert(struct link *node);

void main()
{
          clrscr();

          node=(struct link *)malloc(sizeof(struct link));
          create_link(node);

          printf("\n Output\n");

          display(node);

          insert(node);
          printf("\n list after insertion ");
          display(node);

          getch();
}

void create_link(struct link *node)
{
          char ans;

          start->next=NULL;
          node=start;
          node->next= (struct link *)malloc(sizeof(struct link));

          fflush(stdin);
          printf("\n Enter 'n' for break:-");
          ans=getchar();
          while(ans!='n')
          {
                   node->next=(struct link *)malloc(sizeof(struct link));
                   node=node->next;
                   printf("\n Enter data for node:-");
                   scanf("%d",&node->no);
                   node->next=NULL;
                   fflush(stdin);
                   printf("\n Enter 'n' for break:-");
                   ans=getchar();
                   i++;
          }
          printf("\n Total node in header linked list : %d",i);
          node=start;
          node->no=i;// save total no. of node in header node
}

void display(struct link *node)
{
          int count;
          node=start;
          count=node->no;
          node=node->next;
          while(count>0)
          {
                   printf("\n  %d",node->no);
                   node=node->next;
                   count--;
          }
}

void insert(struct link *node)
{
          int node_no=1,insert_no,flag=0,count;

          node=start;
          count=node->no;

          node=node->next;
          pre=start;

          printf("\n Enter position where you want to insert new node:- ");
          scanf("%d",&insert_no);

          while(count>0)
          {
                   if(node_no==insert_no)
                   {
                             new1=(struct link *)malloc(sizeof(struct link));
                             printf("\n Insert data for new node : ");
                             scanf("%d",&new1->no);
                             pre->next=new1;
                             new1->next=node;
                             flag=1;

                             break;
                   }
                   else
                   {
                             pre=pre->next;
                             node=node->next;
                   }
                   node_no++;
                   count--;
          }

          if(flag==0)
          {
                   printf("\n Position not found");
          }
          else
          {
          node=start;
          node->no=node->no+1;
      }
}


Posted By : Ruchita Pandya

1 comment:

  1. Las Vegas casinos that are open to COVID-19 vaccine
    The Las Vegas-area 포천 출장마사지 casinos and tribal 아산 출장샵 casinos have since 화성 출장마사지 been approved by the State of Nevada 광양 출장마사지 to offer vaccination at 속초 출장마사지 select locations. The

    ReplyDelete