数据结构舞伴问题

舞伴问题

1、先建立一个舞者队列,依次往队列中添加人员信息;

2、分别创建男女队列;

3、从舞者队列中依次将队首元素出队并判断其性别并添加至男队或女队;

4、分别从男队和女队出队队首元素并配对输出;

5、将未完成的一队队首元素输出(男队的队首成员名称);

二、主要函数算法步骤及代码展示

【算法步骤】

1、初始化Mdancers队列和Fdancers队列;

2、反复循环,依次将跳舞者姓名根据性别插入Mdancers队列和Fdancers队列;

3、当Mdancers队列和Fdancers队列均为非空时,反复循环,依次输出男女舞伴的姓名;

4、如果Mdancers队列为空和Fdancers队列为非空时,则输出Fdancers对列的队头女士的姓名;

5、如果Fdancers队列为空和Mdancers队列为非空时,则输出Mdancers队列的队头男士的姓名;

【算法描述】

//舞伴问题解决
void dancersolve(Person dancer[], int num, int m, SqQueue male, SqQueue female)
{//结构体数组中dancer中存放跳舞的男女姓名,num是跳舞的人数
    for (int j = 0; j < m; j++)
    {
        cout << "第" << j + 1 << "轮:" << endl;
        for (int i = 0; i < num; i++)
        {
            if (dancer[i].sex == 'F')
                EnQueue(female, dancer[i]);//插入女队
            else
                EnQueue(male, dancer[i]);//插入男队
        }
        cout <&
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值