- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)