C语言课程设计---将一个链表按逆序排列.docxVIP

C语言课程设计---将一个链表按逆序排列.docx

  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文档。上传文档
查看更多
C语言课程设计---将一个链表按逆序排列

C语言课程设计题目:将一个链表按逆序排列,即将链头当链尾,链尾当链头学生姓名: 学生学号: 所在专业: 任课教师: 2011年05月28日 实验内容及步骤?一、 设计目的?(1) 加深对c语言课程的理解和分析,进一步巩固c语言的语法及其结构?。(2) 熟练运用和掌握链表的应用?。(3)掌握基本C语言小程序设计。 二、 设计思路?(1)在编写函数的过程中需用到结构体定义和指针函?(2)用do….while语句实现循环?(3)开辟一个结点,并使p1、p2、head指向新结点三、设计体会 N-S图如下链表当前长度 len=1开辟一个新结点,并使p1、p2、head指向它读入第一个结点的数据p1-num当p1-num!=0 开辟一个新结点,并使p1指向它 读入一个数给p1-num p1-num=0 T F使p2-nex=NULL,即上一次输入的结点作为链表尾p2-next=p1p2=p1len++即把p1所指的新结点连到p2所指的结点后面,然后再使p2也指向p1所指向的结点 P1=head使p1指向表头结点 输出p1-num P1-next!=NULL T FP1=P1-next使p1向右移,指向下一结点直到p1-next=NULL为止输出表尾结点数据 for(i=0;ilen;i++)P1=p2=head使p1 、p2都指向表头元素 当p1不是表尾元素P2=p1,使p2指向p1当前指的结点p1=p1-next,p1指向后一个结点 i=0 T Fnewhead=new=p1使new、newhead都指向原链表中的表尾结点new-next=p1new=p1即把p1指向的结点连到new所指的节点后面,然后使new也指向p1所指结点P2-next=NULL,使p2所指的结点作为表尾结点 输出新链表详细设计#include stdio.h#include malloc.hstruct stu{int num;struct stu * next;};第3部分p1=head;printf(\noriginal list:\n);do{printf(%4d,p1-num);if(p1-next!=NULL)p1=p1-next;}while(p1-next!=NULL);printf(%4d,p1-num);for(i=0;ilen;i++){p2=p1=head;while(p1-next!=NULL){p2=p1;p1=p1-next;}if(i==0)newhead=new=p1;elsenew=new-next=p1;p2-next=NULL;}五、设计体会通过为期一周的/zuoye/kechengzhuanye/ \t _blank课程设计,我们对《C语言》这门/zuoye/kechengzhuanye/ \t _blank课程有了更深一步的学习。并有了一个更深的理解,我充分认识到C语言这门课的重要性,我们应该通过这为期一周的学习,掌握以前课堂上没有明白的知识点,加深印象并巩固基础。附录:源程序#include stdio.h#include malloc.hstruct stu{int num;struct stu * next;};void main(){int len=1,i; struct stu * p1,* p2,* head,* new,* newhead; p1=p2=head=(struct stu *)malloc(sizeof(struct stu)); printf(input number(0:list end):); scanf(%d,p1-num); while(p1-num==0); {p1=(struct stu*)malloc(sizeof(struct stu)); printf(input number(0:list end):);scanf(%d,p1-num);if(p1-num==0)p2-next=NULL;else{p2-next=p1;p2=p1;len++;}}p1=head;printf(\noriginal list:\n);do{printf(%4d,p1-num);if(p1-next!=NULL)p1=p1-next;}while(p1-next!=NULL);printf(%4d,p1-num);for(i=0;ilen;i++){p2=p1=head;while(p1-next!=NUL

文档评论(0)

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

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

1亿VIP精品文档

相关文档