c语言—结构体课件.ppt

  1. 1、本文档共40页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 资料仅可参考,如有不妥,请联系本人改正或者删除。 * 用链表处理该问题的基本思路: 将各学生的数据进行离散存放,来一个学生就分配一小块内存(结点)。并将各结点用指针依次连接起来─链表。 每结点应包含下一结点的开始地址。 最后一个结点中的指针为空。 链头指针指向第一个结点,是访问链表的重要依据。 这样的链表称单向链表。 head 学号 成绩 指针 学号 成绩 指针 学号 成绩 指针 学号 成绩 指针 学号 成绩 NULL 一个结点可用如下结构体描述: typedef struct student { int num; 学号 int score; 成绩 struct student *next; 下一结点的首地址 } STU; typedef : 自定义类型符(见11.10) ■单向链表的建立 ①输入一个学生的数据。 ②分配结点空间,数据存入。 ③将该结点的首地址赋给上一结点的next,若该结点是第一个结点,则赋给头指针。 ④将该结点的next置为空,表示该结点为当前的最后结点。 head 学号 成绩 next 学号 成绩 next 学号 成绩 next 学号 成绩 next 学号 成绩 NULL STU *creat() { STU st,*p0=NULL,*p,*head=NULL; while(1) { scanf("%d%d",&st.num,&st.score); if(st.num<0) break; p=malloc(sizeof(STU)); *p=st; (*p).next=NULL; if(p0==NULL) head=p; p0为前一结点的指针 else (*p0).next=p; p0=p; } return head; } head 学号 成绩 next 学号 成绩 next 学号 成绩 NULL ■单向链表的访问 以输出为例 ①通过头指针找到第一个结点. ②输出当前结点的内容,并通过next找到后继结点,┄┄,直到next为空. void output(STU *head) { STU *p=head; while(p) { printf("\n %d %d",(*p).num,(*p).score); p=(*p).next; } } head 学号 成绩 next 学号 成绩 next 学号 成绩 NULL 学号 成绩 next ■删除结点操作 ①按链表的访问方法找到相应结点。 ②若该结点是第一个结点,则将后继结点指针赋给头指针。 若该结点是最后一个结点,则将前缀结点的next置为空。 若该结点是中间结点,则将后继结点指针赋给前缀结点的next。 ③释放该结点所占的内存单元。 head 学号 成绩 next 学号 成绩 next 学号 成绩 NULL STU *delete(STU *head,int number) { STU *p =head,*p0=NULL; while(p) { if((*p).num==number) { if(p==head) head=(*p).

文档评论(0)

181****8523 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档