结构体(带头结点单链表).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
//带头结点的单链表.cpp #define NULL 0 struct student {char sno[6]; //学号域5个字符 char name[9]; //姓名域4个汉字 struct student *next; //指针域 }; typedef struct student st; #include stdlib.h #include stdio.h #include string.h st *createlink() {//尾插法建立带头结点的动态单链表,返回头指针。 st *head,*p,*r; r=head=(st *)malloc(sizeof(st)); //生成头结点 p=(st *)malloc(sizeof(st)); //分配新结点 printf(学号:); gets(p-sno); printf(姓名:); gets(p-name); while (strcmp(p-sno,#)!=0)//当学号为字符串#时结束循环 {r-next=p; //新结点链入表尾 r=p; //表尾指针后移 p=(st *)malloc(sizeof(st)); //分配新结点 printf(学号:); gets(p-sno); printf(姓名:); gets(p-name); } r-next=NULL; //最后结点指针域为空 free(p); //释放最后输入学号为#的结点 return head; } void outlink(st *head) {//输出以head为头指针的单链表 st *p; if (!head-next) {printf(Empty LinkList.\n); exit(0);} p=head-next; while (p!=NULL) {printf(%s %s\n,p-sno,p-name); p=p-next; } } void insertNode(st *head, st *s) {//在以head为头指针且按学号升序排列的单链表中插入指针s所指向的结点仍按升序排列 //返回插入结点后新链表头指针 st *p1,*p2; p1=head-next; p2=head; while (p1!=NULLstrcmp(p1-sno,s-sno)0) {p2=p1; p1=p1-next;} //寻找插入位置 p2-next=s; s-next=p1; return; } void deleteNode(st *head,char *s) {//在以head为头指针的单链表中删除给定学号s所在的结点 st *p1,*p2; if (!head-next) {printf(Empty LinkList.\n); exit(0);} p1=head-next; p2=head; while (p1!=NULLstrcmp(p1-sno,s)!=0) {p2=p1; p1=p1-next;} //p1指向要删除的结点,p2指向要删结点的前一结点 if (p1==NULL) printf(链表中无所删结点!\n); else {p2-next=p1-next; free(p1); } //删除p1所指结点 } void main() {st *head,*s; char no[6]; char c; while (1) {printf(1.建立链表\n); printf(2.显示链表\n); printf(3.插入结点\n); printf(4.删除结点\n); printf(0.结 束\n); printf(请输入0--4:); c=getchar(); getchar(); switch (c) {case 0: return; case 1: head=createlink(); break; case 2: outlink(head); break; case 3: s=(st *)malloc(sizeof(st)); printf(输入要插入的节点:\n); printf(学号:); gets(s-sno); printf(姓名:); gets(s-name); insertNode(head,s); break; case 4: printf(输入要删除的学号:\n); printf(学号:);

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档