数据结构加里森的任务实验报告.docxVIP

  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)根据输入的(n,x,y),通过程序显示每轮派出去执行任务的战士的编号,直至只剩一人的情况,判断是否编号为1的加里森能否最终留下; 2)根据输入的n值,找出从(n,1,1)到(n,n,n)满足条件的三元数对;3)退出程序。 2,输入以及输出 输入输出限制:n为大于等于2的正整数,x为大于等于1小于等于n的正整数,y为大于等于1的正整数(题干没有明确限制,默认小于等于n); 输入输出形式:对于功能一,输入符合要求的n,x,y,输出每轮派出的战士编号,yes/no表示加里森能否最后留下;对于功能二,输入符合要求的n,输出从(n,1,1)到(n,n,n)满足条件的三元数对;对于功能三,输出“程序已停止”。 3,正确的输入输出范例一: 正确的输入输出范例二: 正确的输入输出范例三: 错误的输入输出范例一: 错误的输入输出范例二: 概要设计 本程序主要实现了两个功能。 功能一思路,先判断输入的n,x,y是否合理,如合理,则将编号1-n存入一个循环链表,头指针移到编号x时开始计数,指针向后移动y-1次,输出当前指针所存节点的编号,即为该轮被淘汰的战士编号,然后再把该节点删除,指针后移一位重新计数,重复上述操作,直至只留下一个节点为止。若最后一个节点编号为1,则加里森留下;否则未留下。 功能二思路,先判断输入的n是否合理,如合理,则构建二重for循环(i,j,1=i=n, 1=j=n)列举从(n,1,1)到(n,n,n)所有可能的nxy组合并进行判断,一旦符合则输出该组合。直至循环完毕。 判断方法有两种,第一种类似功能一,第二种利用约瑟夫环公式法。 数据结构类型的定义: typedef struct Link{ int num; struct Link *next; }link; 主程序流程: int main(){ int choice,t; int n,x,y; printf(功能选择:\n); printf(1,自拟数据验证程序正确性(n,x,y已知,验证1号能否留下)\n); printf(2,输出符合条件的(n,x,y)组合(n已知)\n); printf(0,退出程序\n); printf(请选择功能:); scanf(%d,choice); if(choice==1) { printf(请输入n,x,y:); scanf(%d %d %d,n,x,y); t=fanwei1(n,x,y); } if(choice==2) { printf(请输入n:); scanf(%d,n); t=fanwei2(n); } if(choice==1t==1) judge(n,x,y); if(choice==2t==1) { int i,j; for(i=1;i=n;i++) { for(j=1;j=n;j++) { if (Cleanjudge(n,i,j)==1) //也可调用Rejudge printf((%d,%d,%d) ,n,i,j); } printf(\n); } } //可调用函数 judge,Cleanjudge,Rejudge if(choice==0) printf(程序已停止); } 程序模块之间的调用关系: Main函数先调用fanwei1函数或fanwei2函数判断输入是否合法,功能一接着调用judge函数,功能二接着调用Cleanjudge函数或Rejudge函数。(judge函数和Cleanjudge函数中都调用了creatLinkList函数) 详细设计 1)//创建循环链表的函数 void creatLinkList(link *p,int n){ link *temp=p; link *head=p;//记录起点 for (int i=1; i=n; i++) { link *a=(link*)malloc(sizeof(link)); a-num=i; a-next=NULL; temp-next=a; temp=temp-next; if (i==n) a-next=head-next;//尾接头,使得循环 } } 2)void judge(int n,int x,int y)//这个是带输出淘汰过程的判断 { //n:人

文档评论(0)

177****6330 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档