猴子选大王数据结构课程设计报告内附详细注释资料.docVIP

猴子选大王数据结构课程设计报告内附详细注释资料.doc

  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文档。上传文档
查看更多
1.需求分析 问题定义:一堆猴子都有编号,编号是1,2,3…n,这群猴子(n个)按照1-n的顺序围坐一圈,从第1个开始数,每数到第m个,该猴子就要离开此圈,这样依次下来,直到圈中只剩下最后一只猴子,则该猴子为大王。m,n键盘输入,且mn,输出为大王的猴子的号数。 问题分析:根据任务描述可知,编号是1,2,3…n的一群猴子按照1-n的顺序围坐一圈,因此可以用指针指向数组的方法给数组赋值,输入n值和m值,为保证mn,用一个while( )语句实现,如果输错,报错,再输入。用for循环实现猴子编号。从1开始数到m的猴子出列,即用指针移动查找法将计数器数到m的指针指向的内容变为0,用for循环,直到只有一个元素不为0时,最后不为0的元素的值即为大王。实现这个程序功能需3个模块,一个模块用数组指针实现猴子编号,一个模块用指针移动查找法实现猴子出局,最后主模块将前两个模块要用到的函数,数组定义。具体步骤如下: 第一步 建立数组,填入猴子编号及猴子出局时报的数 第二步 从第一个猴子报数 第三步 数到m让指针指向元素变为0 第四步 继续报数,重复第三步 2.概要设计(流程图) 开始 定义结构体,变量 定义结构体,变量 Calloc( )分配内存 For循环 建立数组 建立数组 赋值实现猴子编号 指针移动查找 Count=n-1 猴子数数F 猴子数数 For(i=0;count!=0;ptr2++) If(Ptr2==ptr+n) Ptr2=ptr; 保证猴子围成圈 *ptr2=0 ? i++ N *ptr2=0 ? i++ i++ Y i==m ? i==m ? N Y *ptr2=i=0 *ptr2=i=0 Count-- C Count==0 ? N Y 输出大王号数 输出大王号数 break 3.详细设计 #includestdio.h #includestdlib.h //使用calloc()函数 void FindKing_pointer(int,int,int*);//移动指针法找大王 void Initialize(int,int*);//初始化数组 整形和指针型 int main() { int m,n,*ptr; printf(输入猴子数与出局时报的数\n); scanf(%d %d,n,m); while(nm) { printf(输入数据有误,请重新输入!\n); printf(输入猴子数与出局时报的数\n); scanf(%d %d,n,m); } ptr=(int *)calloc(n

文档评论(0)

开心农场 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档