版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、数据结构与算法设计实验报告实验一学院:自动化学院班级:06111001学号:1120101525姓名:王冬一、 实验目的 1、熟悉VC环境,学习使用C语言利用链表的存储结构解决实际的问题。2、在编程、上机调试的过程中,加深对线性链表这种数据结构的基本概念理解。3、锻炼较强的思维和动手能力和更加了解编程思想和编程技巧。二、实验内容 1、 采用单向环表实现约瑟夫环。请按以下要求编程实现: 从键盘输入整数m,通过create函数生成一个具有m个结点的单向环表。环表中的结点编号依次为1,2,m。 从键盘输入整数s(1=s0,n0,s环表结点数。操作结果:返回约瑟夫环的计算结果。ADT Joh(2)宏定
2、义#define NULL 0 #define OK 1#define ERROR -1 (3)主程序流程开始输入数据(m,s,n)创建环表输出建立好的环表计算处理输出结果结束(4) 模块调用关系程序分为下述模块:1)主函数模块执行输入调用其他的功能函数 2)创建环表模块创建单向环表 3)计算处理模块计算出要出列的标号并输出 4)显示模块输出建立好的环表 调用关系如下: 主函数模块 创建环表模块 显示模块 计算处理模块 2、详细设计(1)数据类型设计typedef int ElemType; /元素类型typedef struct ElemType data;struct Joh *next;
3、Joh, *LinkList,*p; /结点类型,指针类型(2)操作算法Status create(LinkList &J,int n)/创建一个有n个结点的单向环表if(n=0)return ERROR;/ndata=1;J-next=J;/建立第一个结点for(int i=n;i1;-i)p=(LinkList)malloc(sizeof(J);p-data=i;p-next=J-next;J-next=p;/插入到表头return OK;/create void show(LinkList J)/主要的操作函数/顺序输出环表J的结点p=J;printf(%d ,p-data);p=p-n
4、ext;while(p!=J) /循环终止条件printf(%d ,p-data);p=p-next;/showvoid calculate(LinkList J,int s,int n)p=J;Joh *head=p; /声明结点while(p-data!=s)p=p-next;head=p;/寻找起始结点while(p-next!=p) /终止条件for(int i=0;inext;printf(%d ,p-data);head-next=p-next; /删除已输出结点p=head-next;if(n!=1)printf(%dn,p-data);elseprintf(n);/calcul
5、ate(3)主函数代码int main()/主函数Joh *J;int m,s,n;printf(The num of node is:);scanf(%d,&m);create(J,m); /创建单向环表Jshow(J); /输出J的数据printf(n);printf(The first node which you want is:);scanf(%d,&s);printf(The internal which you want is:);scanf(%d,&n);calculate(J,s,n); /计算并输出结果return 0;/main四、程序调试分析 1、细节决定成败,编程最需
6、要的是严谨,如何的严谨都不过分,往往检查了半天发现错误发生在某个括号,分号,引号,或者数据类型上。在写主要操作函数caculate()时,在终止条件的书写处不是很清楚,导致我浪费了很多时间。 2、还有一点很大的感触就是,在自己绞尽脑汁都解决不了遇到的问题时,一个很好的手段就是询问同学,寻求其帮助,就比如我在想函数终止条件时,同学一句简单的话语就让我如梦初醒。这不是什么丢脸的事情,相反的,在快速解决问题的同时,还会收获友谊,不是一举两得吗。我想,这也是合作学习的真谛吧。五、用户使用说明 1、本程序的运行环境为Windows操作系统下的Microsoft Visual C+ 6.0。2、在VC环境
7、下打开程序后,按要求键入要求的数字,以等号或空格断开,敲击“回车符”,即可以显示要求的结果。3、按下任意键以继续。 六、程序运行结果测试用例1:输入:m=10,s=3,n=4 输出:6,10,4,9,5,2,1,3,8,7测试用例2: 输入:m=13,s=4,n=3 输出:6,9,12,2 ,5,10 ,1, 7 ,13 ,8 ,4 ,11 ,3七、程序清单#define NULL 0 #define OK 1#define ERROR 0typedef int Status;typedef int ElemType; typedef struct /结点类型ElemType data;str
8、uct Joh *next;Joh,*LinkList;/定义约瑟夫结构Joh *p;#includestdio.h#includestdlib.hStatus create(LinkList &J,int n)if(ndata=1;J-next=J;/建立第一个结点for(int i=n;i1;-i)p=(LinkList)malloc(sizeof(J);/申请空间p-data=i;p-next=J-next;J-next=p;/插入到表头return OK;/构造函数void show(LinkList J)p=J;printf(%d ,p-data);p=p-next;while(p!
9、=J) /循环结束条件printf(%d ,p-data);p=p-next;/显示函数void calculate(LinkList J,int s,int n)p=J;Joh *head=p;while(p-data!=s)p=p-next;head=p;/寻找起始结点while(p-next!=p)for(int i=0;inext;printf(%d ,p-data);head-next=p-next; /删除已输出结点p=head-next;if(n!=1)printf(%dn,p-data);elseprintf(n);/主体计算函数int main()Joh *J;int m,s,n;printf(The num of node is(m=):);scanf(%d,&m);create(J,m); /创建单向环表Jshow(J); /显示J的数据内容printf(
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 脊髓损伤临床诊治规范
- 新闻学科普知识
- 核医学检查流程培训
- 如何构建教师团队的合作精神
- 管理保安岗位培训
- 2026河南省人力资源开发中心有限公司招聘5人备考题库及参考答案详解(研优卷)
- 腹腔植入导管的护理
- 北大本科考试题(法理学)
- 2026陕西延安北方医院招聘备考题库带答案详解(培优)
- 2026贵州贵阳贵安招聘中小学(幼儿园)教师819人备考题库及完整答案详解(夺冠)
- CJJT 182-2014 城镇供水与污水处理化验室技术规范
- 中国电信安徽公司校园招聘试卷
- 两单两卡安全培训
- 2023年陕西省西安新城区校园招聘高层次及特殊紧缺人才(15人)笔试历年难、易点深度预测(共500题含答案解析)模拟试卷
- ATLAS空压机常见故障分析和处置
- 220kV变电站220kV母差B套保护装置换型工程四措一案
- 2023届二轮复习 第四单元 第9课 走向整体的世界 学案
- 2023版思想道德与法治专题1担当复兴大任 成就时代新人PPT
- 现代设计理论与方法(上)
- 人教版八年级下册生物全册教案完整版教学设计含教学反思
- 宠物店如何给宠物做SPA
评论
0/150
提交评论