早教吧作业答案频道 -->其他-->
C语言实现舞伴问题(队列)假设在周末舞会上,男士们(m人)和女士们(n人)进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不
题目详情
C语言实现舞伴问题(队列)
假设在周末舞会上,男士们(m人)和女士们(n人)进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不相同,则较长的那一队中未配对者等待下一轮舞曲。现要求写一算法模拟上述舞伴配对问题。并求m和n存在什么条件时,第x个(1<=x<=m)男生才有可能和他心仪的第y个(1<=y<=n)女生跳舞,在第几首曲子时?
假设在周末舞会上,男士们(m人)和女士们(n人)进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不相同,则较长的那一队中未配对者等待下一轮舞曲。现要求写一算法模拟上述舞伴配对问题。并求m和n存在什么条件时,第x个(1<=x<=m)男生才有可能和他心仪的第y个(1<=y<=n)女生跳舞,在第几首曲子时?
▼优质解答
答案和解析
#includetypedef struct que{
int *qu;
int front,rear;
}Squeue;
void Initqueue(Squeue *q,int len);
void Enqueue(Squeue *q,int n,int len);
int Dequeue(Squeue *q,int len);
int main()
{ int m,n,x,y,i,j,num=0;
Squeue q1,q2;
scanf("%d%d",&m,&n);//Input m and n;
Initqueue(&q1,m);
Initqueue(&q2,n);
for(i=0;i for(i=0;i if(x!=y&&m==n) { printf("No chance");sleep(1000);exit(0);}
i=Dequeue(&q1,m);
j=Dequeue(&q2,n);
printf("MW\n");
while(!(x==i&&y==j))
{Enqueue(&q1,i,m);
Enqueue(&q2,j,n);
printf("%d%d\n",i,j);
i=Dequeue(&q1,m);
j=Dequeue(&q2,n);
num++;
}
printf("%d%d\n",i,j);
printf("The number is %d\n",num+1);
free(q1.qu);
free(q2.qu);
system("pause");
return 0;
}
void Initqueue(Squeue *q,int len)
{
q->qu=(int*)malloc(len*sizeof(int)) ;
if(!q->qu) exit(0);
q->front=q->rear=0;}
void Enqueue(Squeue *q,int n,int len)
{q->qu[q->rear]=n;
q->rear=(q->rear+1)%len;
}
int Dequeue(Squeue *q,int len)
{int e;
e=q->qu[q->front];
q->front=(q->front+1)%len;
return e;
}在dev和win_tc中通过,在用队列的时候,没有考虑特殊情况,没影响。下面未用队列的算法似乎是很简单,也可以在dev 和win_tc上通过
#include
int main()
{ int m,n;
int i,j,k=0;
int x,y;
printf("Input the number of ladies and gentlemen:");
scanf("%d%d",&m,&n);
printf("Input the location of the man and the woman:");
scanf("%d%d",&x,&y);
if(m==n&&x!=y) printf("No chance!");
else
{for(i=0,j=0;!(i==x&&j==y);i=(i+1)%m,j=(j+1)%n)
{printf("man(%d)woman(%d)\n",i+1,j+1); k++;}
printf("\nThe number of song is:%d\n",k);
}
system("pause");
return 0;
}
int *qu;
int front,rear;
}Squeue;
void Initqueue(Squeue *q,int len);
void Enqueue(Squeue *q,int n,int len);
int Dequeue(Squeue *q,int len);
int main()
{ int m,n,x,y,i,j,num=0;
Squeue q1,q2;
scanf("%d%d",&m,&n);//Input m and n;
Initqueue(&q1,m);
Initqueue(&q2,n);
for(i=0;i
i=Dequeue(&q1,m);
j=Dequeue(&q2,n);
printf("MW\n");
while(!(x==i&&y==j))
{Enqueue(&q1,i,m);
Enqueue(&q2,j,n);
printf("%d%d\n",i,j);
i=Dequeue(&q1,m);
j=Dequeue(&q2,n);
num++;
}
printf("%d%d\n",i,j);
printf("The number is %d\n",num+1);
free(q1.qu);
free(q2.qu);
system("pause");
return 0;
}
void Initqueue(Squeue *q,int len)
{
q->qu=(int*)malloc(len*sizeof(int)) ;
if(!q->qu) exit(0);
q->front=q->rear=0;}
void Enqueue(Squeue *q,int n,int len)
{q->qu[q->rear]=n;
q->rear=(q->rear+1)%len;
}
int Dequeue(Squeue *q,int len)
{int e;
e=q->qu[q->front];
q->front=(q->front+1)%len;
return e;
}在dev和win_tc中通过,在用队列的时候,没有考虑特殊情况,没影响。下面未用队列的算法似乎是很简单,也可以在dev 和win_tc上通过
#include
int main()
{ int m,n;
int i,j,k=0;
int x,y;
printf("Input the number of ladies and gentlemen:");
scanf("%d%d",&m,&n);
printf("Input the location of the man and the woman:");
scanf("%d%d",&x,&y);
if(m==n&&x!=y) printf("No chance!");
else
{for(i=0,j=0;!(i==x&&j==y);i=(i+1)%m,j=(j+1)%n)
{printf("man(%d)woman(%d)\n",i+1,j+1); k++;}
printf("\nThe number of song is:%d\n",k);
}
system("pause");
return 0;
}
看了 C语言实现舞伴问题(队列)假...的网友还看了以下:
幼儿教师了解幼儿的最好的信息源来自( )。 A.同龄人B.社区人士C.家长D.教养员 2020-05-17 …
伊拉斯谟说:“许多修道院与公共妓院无甚差别。”反映了中世纪的西欧A.教士和僧侣的腐化荒淫B.天主教 2020-07-02 …
伊拉斯谟说:“许多个修道院与公共妓院无甚差别。”这反映了中世纪的欧洲[]A.教士和僧侣的腐化荒淫B 2020-07-02 …
中共在抗日根据地实行民主政治,根据“三三制”原则建立抗日民主政权。你认为参议会和政府里不可能包括A 2020-07-13 …
图是唐朝的鸿胪寺。唐太宗统治时期,在鸿胪寺经常可以看到的人是A.各国使者B.宗教人士C.少数民族首领 2020-11-03 …
请教专业人士吃的小苏打究竟是什么请问一下相关人士,我们平常发面用的小苏打和化学分析纯的碳酸氢钠究竟成 2020-11-13 …
《分苹果的启示》阅读答案一个人一生中最早受到的教育来自家庭,来自母亲对孩子的早期教育.美国一位著名心 2020-12-03 …
孔子是儒家思想的创立者,这里的“儒”是指A.古代的专业神职人员B.有一定专业知识和技能的人士C.专门 2020-12-08 …
谁帮我写初一英语作文!英语作文,带翻译!假设你是Weloveschool乐队的负责人,你们需要五民音 2020-12-14 …
为什么那些名人们就能有恒心能坚持住?为什么那些成功人士他们就能坚持住?为什么他们那么有恒心?他们为梦 2020-12-22 …