免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1408 | 回复: 0
打印 上一主题 下一主题

链表创建和插入的操作 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-11-30 17:07 |只看该作者 |倒序浏览
#include<stdio.h>
#include<stdlib.h>

typedef struct LNode{
   int data;
   struct LNode *next;
}LNode,*LinkList;

void initlist(LinkList L);
int Inselem(LinkList L,int i,int x);
void displist(LinkList L);
int Getlen(LinkList L);


  main()
{
  LinkList List=NULL;
  
int ii,xx,error,counter;
  
  initlist(List);

  printf("Please enter the linklist size:");
  scanf("%d",&List->data);
  printf("\n");
  for(counter=1;counter<=List->data;counter++){
     printf("Please enter data into linklist:");
     scanf("%d",&xx);  
     Inselem(List,counter,xx);
   }         

  printf("\n\nThe link list:\n");
  displist(List);
  printf("\n");

  printf("\nNow ,please insert element's location and value:");
  scanf("%d%d",&ii,&xx);
  printf("\n");
  error=Inselem(List,ii,xx);

  printf("\n The new link list:\n");

  if(error==1)
     printf("Location error!\n");
  else
     displist(List);

  return 0;
}


void initlist(LinkList L)
{ L=malloc(sizeof(LNode));
     L->next=NULL;
}



int Inselem(LinkList L,int i,int x)
{
  LNode *p,*q,*s;
      int pos=1;
      p=L;
      if(i<1 || i>Getlen(L)+1)
         return 1;
      s=malloc(sizeof(LNode));
      s->data=x;
      while(pos<=i)
      { q=p;p=p->next;
          pos++;
      }
      s->next=q->next;
      q->next=s;
    }



void displist(LinkList L)
{ LNode *p;
      p=L->next;
      while(p!=NULL)
      { printf("%4d",p->data);
        p=p->next;
       }
      printf("\n");
}


int Getlen(LinkList L){
   return L->data;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP