ImageVerifierCode 换一换
格式:DOC , 页数:11 ,大小:110KB ,
资源ID:3675722      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-3675722.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构约瑟夫环实验报告.doc)为本站会员(weiwoduzun)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

数据结构约瑟夫环实验报告.doc

1、数据结构与算法设计约瑟夫环实验报告实验一专业:物联网工程班级:物联网 1 班学号:15180118姓名:刘沛航一、 实验目的 1、熟悉 VC 环境,学习使用 C 语言利用链表的存储结构解决实际的问题。2、在编程、上机调试的过程中,加深对线性链表这种数据结构的基本概念理解。3、锻炼较强的思维和动手能力和更加了解编程思想和编程技巧。二、实验内容 1、 采用单向环表实现约瑟夫环。请按以下要求编程实现: 从键盘输入整数 m,通过 create 函数生成一个具有 m 个结点的单向环表。环表中的结点编号依次为 1,2,m。 从键盘输入整数 s(10,n0 ,sdata=1;J-next=J;/建立第一个结

2、点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-next;while(p!=J) /循环终止条件printf(“%d “,p-data);p=p-next;/showvoid calculate(LinkList J,int s,int n)p=J;Joh *head=p; /声明结点while(

3、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“);/calculate(3)主函数代码int main()/主函数Joh *J;int m,s,n;printf(“The num of node is:“);scanf(“%d“,create(J,m); /创建单向环表 Jshow(J); /输

4、出 J 的数据printf(“n“);printf(“The first node which you want is:“);scanf(“%d“,printf(“The internal which you want is:“);scanf(“%d“,calculate(J,s,n); /计算并输出结果return 0;/main四、程序调试分析 1、细节决定成败,编程最需要的是严谨,如何的严谨都不过分,往往检查了半天发现错误发生在某个括号,分号,引号,或者数据类型上。在写主要操作函数 caculate()时,在终止条件的书写处不是很清楚,导致我浪费了很多时间。 2、还有一点很大的感触就是,

5、在自己绞尽脑汁都解决不了遇到的问题时,一个很好的手段就是询问同学,寻求其帮助,就比如我在想函数终止条件时,同学一句简单的话语就让我如梦初醒。这不是什么丢脸的事情,相反的,在快速解决问题的同时,还会收获友谊,不是一举两得吗。我想,这也是合作学习的真谛吧。五、用户使用说明 1、本程序的运行环境为 Windows 操作系统下的 Microsoft Visual C+ 6.0。2、在 VC 环境下打开程序后,按要求键入要求的数字,以等号或空格断开,敲击“回车符” ,即可以显示要求的结果。3、按下任意键以继续。六、程序运行结果程序测试 1:程序测试 2:七、程序清单#include#include /引

6、用函数库struct LNodeint num;struct LNode *next; /定义链表typedef struct LNode NODE;NODE *createlinklist(int n)/初始化循环链表,并返回头指针NODE *head,*p,*q;int i=1;head=p=(struct LNode*)malloc(sizeof(struct LNode);p-num=i;for(i=2;inext=q;p=q;p-num=i;p-next=head; /使链表尾指向链表头,形成循环链表return head;void joseph(NODE *p,int n,int

7、m)/约瑟夫函数,用于输出约瑟夫环int i,j;NODE *q;for(i=1;inext; /计算出列者序号q=p-next;p-next=q-next;printf(“%d “,q-num);free(q);p-next=NULL;void main()NODE *head;int n,s,m;int i;/确定计算系数printf(“*物理网 1 班-15180118-刘沛航*n“);printf(“围绕圆桌的人数为?n“);scanf(“%d“,printf(“从第几人开始?n“);scanf(“%d“,printf(“数到几的人出列?n“);scanf(“%d“,/确定头指针head=createlinklist(n);if(s=1)for(i=1;inext;elsefor(i=1;inext;/输出约瑟夫环出列顺序printf(“出列的顺序如下:n“);joseph(head,n,m);printf(“n“);

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报