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

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语言实现舞伴问题(队列)假...的网友还看了以下:

请你把下面与石头相关的歇后语补充完整。1.搬石头上山一(请你把下面与石头相关的歇后语补充完整。1.  2020-04-12 …

如果显微镜的镜头上有一些灰尘,下列哪种方法除尘最好A.把手洗净,用手指拭掉灰尘B.放到清水中洗净  2020-05-13 …

静止在水面上的船,船身长为L,质量为M,船头紧靠码头,船头上有一固定木板伸出船身,现有一质量为m的  2020-06-18 …

有甲、乙、丙、丁、戊五个人,每个人头上戴一顶白帽子或者黑帽子,每个人只能看见别人头上帽子的有甲、乙  2020-06-22 …

我们老师要以一段小资料写一篇“渐变”为话题的作文十万火急(资料如下)头上掉一根头发,很正常,在掉一  2020-07-08 …

如果显微镜的镜头上有一些灰尘,下列哪种方法除尘最好()A.把手洗净,用手指拭掉灰尘B.放到清水中洗  2020-12-02 …

.老师和小红、小丽一起做游戏.老师在两张纸片上分别写上两个相邻的一位正整数,然后把一张贴在小红的额头  2020-12-02 …

如图所示是家庭电路中常用的白炽灯泡和灯头的示意图,对于灯泡和灯头上的一些部件,下列选项中全部是绝缘体  2020-12-14 …

阅读下面文章,完成下列各题。做客游睿①今天是青青的十岁生日。放学后,青青并没有像往常一样一上山就砍柴  2021-01-12 …

指出下列语句使用的说明方法。……头和身躯乳白色,而四肢和肩部黑色,头上有一对整齐的黑耳朵,还有两个黑  2021-01-12 …