约瑟夫环数据结构c语言程序,数据结构约瑟夫环实验报告

《数据结构约瑟夫环实验报告》由会员分享,可在线阅读,更多相关《数据结构约瑟夫环实验报告(13页珍藏版)》请在人人文库网上搜索。

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

2、1;-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(p-data!=s)p=p-next;h。

3、ead=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,&m);create(J,m); /创建单向环表Jshow(J); /输出J的数据printf(n);printf(The f。

4、irst 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、细节决定成败,编程最需要的是严谨,如何的严谨都不过分,往往检查了半天发现错误发生在某个括号,分号,引号,或者数据类型上。在写主要操作函数caculate()时,在终止条件的书写处不是很清楚,导致我浪费了很多时间。 2、还有一点很大的感触就是,在自己绞尽脑汁都解决不了遇到的问题时,一个很好的手段就是询问同学。

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

6、xt; /定义链表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 m)/约瑟夫函数,用于输出约瑟夫环int i,j;NODE *q;for(i=1。

7、;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,&n);printf(从第几人开始?n);scanf(%d,&s);printf(数到几的人出列?n);scanf(%d,&m);/确定头指针head=createlinklist(n);if(s=1)for(i=1;inext;elsefor(i=1;inext;/输出约瑟夫环出列顺序printf(出列的顺序如下:n);joseph(head,n,m);printf(n);13 / 13文档可自由编辑。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值