数据结构(三):舞伴配对问题(C++,队列)
好家伙,
题目如下:
1.舞伴配对问题:假设在周末舞会上,男士们和女士们进入舞厅时,各自排成一队。跳舞开始时,依次从男队和女队的队头上各出一人配成舞伴。
2.若两队初始人数不相同,则较长的那一队中未配对者等待下一轮舞曲。要求编写程序,模拟上述舞伴配对问题,且规定:
程序的输入时:进入舞厅人员的姓名和性别。
程序输出是:如果是配对的,则输出两个舞伴的人的姓名;
如果是未配成对的,则输出等待配对的人数和下一轮舞曲开始时第一个可获得舞伴的人。
题目分析如下:
首先建立两个队列,一个队列存放男士,一个队列存放女士,
配对时,每轮每个队列的队头元素出来配对,未配对的放到下一轮继续配对。
最后,将有剩余的男或女输出
(用m和f分别表示男和女,m:male,f:female)
#include <iostream>
using namespace std;
//定义一个人的结构体,用于存放参加舞会的人员的名字和性别
typedef struct
{
char name[20];
char sex;
}Person; //定义一个队列的结构体,成员变量有结构体数组、头指针、尾指针和队列长度
typedef struct
{
Person person[20];
int front1=0;
int rear=0;
int count1=0;
}SqQuene; //配对函数
void Arrange(Person* person,SqQuene* Male,SqQuene* Female,int num)
{
cout<<"请输入参与舞会的人员的名字和性别:(M/m:男 F/f:女)"<<endl;
//根据你输入的人数,进行循环输入成员的信息,同时根据成员的性别分别插入对应的队列
for(int i = 0;i < num; i++)
{
cin>>person[i].name>>person[i].sex;
if(person[i].sex == 'M' || person[i].sex == 'm')
{
Male->person[Male->rear++] = person[i];
Male->count1++;
}
else if(person[i].sex == 'F' || person[i].sex == 'f')
{
Female->person[Female->rear++] = person[i];
Female->count1++;
}
else
{
cout<<"您的输入有误,请重新输入!"<<endl; //如果输入的性别有误,就重新输入,并保证人数不会出错
i--;
}
} cout<<"配对结果:"<<endl;
cout<<"男 女"<<endl;
while(Male->count1 > 0 && Female->count1 > 0) //当两个队列的个数不为0时,输出两个队列的对头元素
{
cout<<Male->person[Male->front1].name<<"——"<<Female->person[Female->front1].name<<endl;
Male->front1++;
Female->front1++;
Male->count1--;
Female->count1--;
} //如果男士队有剩余,输出男士队的队头元素
if(Male->count1 > 0)
{
cout<<"下一轮男生队伍的第一位:"<<Male->person[Male->front1].name<<endl;
} //如果女士队有剩余,输出女士队的队头元素
if(Female->count1 > 0)
{
cout<<"下一轮女生队伍的第一位:"<<Female->person[Female->front1].name<<endl;
}
//否则无剩余
if(Male->count1 == 0 && Female->count1 == 0)
{
cout<<"该轮无剩余人员!"<<endl;
}
} int main()
{
int num,flag = 1; //定义两个变量,一个存放插入的人数,一个是标志变量
Person* person = new Person[20]; //定义一个结构体数组
SqQuene* female = new SqQuene; //定义一个指向女队列的队列指针
SqQuene* male = new SqQuene; //定义一个指向男队列的队列指针
while(flag == 1) //判断循环条件
{
cout<<"请输入本轮跳舞的人数:"<<endl;
cin>>num;
Arrange(person,male,female,num); //调用配对函数
cout<<"输入1继续"<<endl;
cin>>flag; //判断变量是否满足循环条件
}
delete []person; //释放数组所占空间
cout<<"感谢您的使用,再见!"<<endl;
return 0;
}
输入样例:
panghu m
xiaofu m
jinxiang f
xiaohong f
xiaobing f
输出样例:
男 女
panghu——jinxiang
xiaofu——xiaohong
下一轮女生队伍的第一个:xiaobing
图示:

数据结构(三):舞伴配对问题(C++,队列)的更多相关文章
- SDUT-2133_数据结构实验之栈与队列三:后缀式求值
数据结构实验之栈与队列三:后缀式求值 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 对于一个基于二元运算符的后缀表示式 ...
- C语言数据结构——第三章 栈和队列
三.栈和队列 栈和队列是两种重要的线性结构.从数据结构的角度来看,栈和队列也是线性表,它的特殊性在于栈和队列的基本操作是线性表操作的子集,它们的操作相对于线性表来说是受到限制的,因此,可以称其为限定性 ...
- 学习javascript数据结构(三)——集合
前言 总括: 本文讲解了数据结构中的[集合]概念,并使用javascript实现了集合. 原文博客地址:学习javascript数据结构(三)--集合 知乎专栏&&简书专题:前端进击者 ...
- 数据结构图文解析之:队列详解与C++模板实现
0. 数据结构图文解析系列 数据结构系列文章 数据结构图文解析之:数组.单链表.双链表介绍及C++模板实现 数据结构图文解析之:栈的简介及C++模板实现 数据结构图文解析之:队列详解与C++模板实现 ...
- SDUT-3334_数据结构实验之栈与队列七:出栈序列判定
数据结构实验之栈与队列七:出栈序列判定 Time Limit: 30 ms Memory Limit: 1000 KiB Problem Description 给一个初始的入栈序列,其次序即为元素的 ...
- 自己动手实现java数据结构(八) 优先级队列
1.优先级队列介绍 1.1 优先级队列 有时在调度任务时,我们会想要先处理优先级更高的任务.例如,对于同一个柜台,在决定队列中下一个服务的用户时,总是倾向于优先服务VIP用户,而让普通用户等待,即使普 ...
- 数据结构与算法Java描述 队列
package com.cjm.queue; /** * 数据结构与算法Java实现 队列 * * @author 小明 * */ public class Myqueue { private Nod ...
- (三)RabbitMQ消息队列-Centos7下安装RabbitMQ3.6.1
原文:(三)RabbitMQ消息队列-Centos7下安装RabbitMQ3.6.1 如果你看过前两章对RabbitMQ已经有了一定了解,现在已经摩拳擦掌,来吧动手吧! 用什么系统 本文使用的是Cen ...
- SDUT-2088_数据结构实验之栈与队列十一:refresh的停车场
数据结构实验之栈与队列十一:refresh的停车场 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description refresh最近发 ...
- SDUT-2449_数据结构实验之栈与队列十:走迷宫
数据结构实验之栈与队列十:走迷宫 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 一个由n * m 个格子组成的迷宫,起 ...
随机推荐
- 软件缺陷(bug)
生活中我们肯定听过身边的朋友说过:'这tm就是个bug','你就是bug一样的存在' 等话语.当你听到这句话的时候或许有些懵逼或许认为这货说的什么玩意.其实当你想成为一名测试工程师的时候你就要天天和b ...
- KubeSphere2.1踩坑记
至少两台机器.推荐4X16.(完全安装KubeSphere会吃掉10G+内存) k8s安装(略1.14.8)可参考我上一篇文章或者基于kubeadmin快速安装 KubeSphere2.1前置条件 1 ...
- 2020美亚个人赛wp
案例背景 2020年9月,数名信用卡持有人向警方报案,指他们的信用卡被不知名人士在一家本地网上商店购买手机.订单大部分来自海外的网络地址,但有一宗订单来自本地.警方经调查后发现该本地网络地址的注册地址 ...
- TienChin 活动管理-删除活动
后端 ActivityController.java @PreAuthorize("hasPermission('tienchin:activity:remove')") @Log ...
- 深度学习应用篇-计算机视觉-视频分类[8]:时间偏移模块(TSM)、TimeSformer无卷积视频分类方法、注意力机制
深度学习应用篇-计算机视觉-视频分类[8]:时间偏移模块(TSM).TimeSformer无卷积视频分类方法.注意力机制 1.时间偏移模块(TSM) 视频流的爆炸性增长为以高精度和低成本执行视频理解任 ...
- numpy数组拼接方法介绍(concatenate)---一次性完成多个数组的拼接
1.数组拼接方法一 思路:首先将数组转成列表,然后利用列表的拼接函数append().extend()等进行拼接处理,最后将列表转成数组. 示例1: >>> import numpy ...
- Python 使用SQLAlchemy数据库模块
SQLAlchemy 是用Python编程语言开发的一个开源项目,它提供了SQL工具包和ORM对象关系映射工具,使用MIT许可证发行,SQLAlchemy 提供高效和高性能的数据库访问,实现了完整的企 ...
- 19.9 Boost Asio 同步字典传输
这里所代指的字典是Python中的样子,本节内容我们将通过使用Boost中自带的Tokenizer分词器实现对特定字符串的切割功能,使用Boost Tokenizer,可以通过构建一个分隔符或正则表达 ...
- 11.1 C++ STL 应用字典与列表
C++ STL 标准模板库提供了丰富的容器和算法,这些模板可以灵活组合使用,以满足不同场景下的需求.本章内容将对前面学习的知识进行总结,并重点讲解如何灵活使用STL中的vector和map容器,以及如 ...
- Python 封装zabbix-get接口
Zabbix 是一款强大的开源网管监控工具,该工具的客户端与服务端是分开的,我们可以直接使用自带的zabbix_get命令来实现拉取客户端上的各种数据,在本地组装参数并使用Popen开子线程执行该命令 ...