早教吧 育儿知识 作业答案 考试题库 百科 知识分享

C语言实现舞伴问题(队列)假设在周末舞会上,男士们(m人)和女士们(n人)进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。若两队初始人数不

题目详情
C语言实现舞伴问题(队列)
假设在周末舞会上,男士们(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;iif(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;
}
看了 C语言实现舞伴问题(队列)假...的网友还看了以下:

我写了一篇作文,麻烦大师们来点评啊,补充也行年少的我他们说我们是年少轻狂,他们说我们不懂事.我们说什  2020-03-31 …

做一做,从2开始,连续的偶数相加,它们的和如下相加的个数和s12=1*222+4+=6=2*332  2020-04-07 …

教堂里的钟1时敲1下,2时敲2下,…12时敲12下,每到半时敲一下,做礼拜的人们从敲1下时开始,到  2020-05-13 …

在不知不觉中,我们的身体经历着一系列微妙的变化。这意味着我们正在长大,开始从儿童向成人过渡,跨入青  2020-05-16 …

如图,小军与李明早晨练习长跑,他们从学校的椭圆形跑道的同一点A出发按相反方向跑步,他们的速度分别为  2020-05-21 …

阅渎这幅漫画,对它的寓意理解最贴切的一项是()A.创造性思维要在实践中善于捕捉灵感.B.我们要抛弃  2020-06-13 …

阅读下列材料:男子主要从事犁耕农业和畜牧业,男子在经济中开始占主导地位。婚姻关系相对固定,人们开始  2020-06-25 …

有时候想想自己的生活,回头看看走过的路。真的想从零开始,从头再来!现实的生活告诉我们那是不可能的!  2020-07-01 …

《这一天》朱自清求读后感这一天是我们新中国诞生的日子.从二十六年这一天以来,我们自己,我们的友邦,  2020-07-02 …

不计算,把①987×1.23,②987×0.123,③98.7×123三个算式按它们的积从小到大排  2020-07-09 …