鱼C论坛

 找回密码
 立即注册
查看: 997|回复: 1

[已解决]求助一下

[复制链接]
发表于 2023-11-14 13:18:26 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
【问题描述】

从标准输入中输入两组整数(每行不超过20个整数,每组整数中元素不重复),合并两组整数,去掉在两组整数中都出现的整数,并按从大到小顺序排序输出(即两组整数集"异或")。

【输入形式】

首先输入第一组整数,以一个空格分隔各个整数;然后在新的一行上输入第二组整数,以一个空格分隔,行末有回车换行。

【输出形式】

按从大到小顺序排序输出合并后的整数集(去掉在两组整数中都出现的整数,以一个空格分隔各个整数)。

【样例输入】

5 1 4 32 8 7 9 -6
5 2 87 10 1
【样例输出】

87 32 10 9 8 7 4 2 -6

这题用C++怎么做
最佳答案
2023-11-14 13:18:34
#include <iostream>
#include <set>
#include <vector>
#include <algorithm>

int main() {
    std::vector<int> firstSet, secondSet, mergedSet;
    int num;

    while (std::cin >> num) {
        firstSet.push_back(num);
        if (std::cin.get() == '\n') {
            break;
        }
    }

    while (std::cin >> num) {
        secondSet.push_back(num);
        if (std::cin.get() == '\n') {
            break;
        }
    }

    std::sort(firstSet.begin(), firstSet.end());
    std::sort(secondSet.begin(), secondSet.end());

    std::set_symmetric_difference(firstSet.begin(), firstSet.end(), secondSet.begin(), secondSet.end(), std::back_inserter(mergedSet), std::greater<int>());

    for (int i = 0; i < mergedSet.size(); ++i) {
        std::cout << mergedSet[ i] << " ";
    }

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-11-14 13:18:34 | 显示全部楼层    本楼为最佳答案   
#include <iostream>
#include <set>
#include <vector>
#include <algorithm>

int main() {
    std::vector<int> firstSet, secondSet, mergedSet;
    int num;

    while (std::cin >> num) {
        firstSet.push_back(num);
        if (std::cin.get() == '\n') {
            break;
        }
    }

    while (std::cin >> num) {
        secondSet.push_back(num);
        if (std::cin.get() == '\n') {
            break;
        }
    }

    std::sort(firstSet.begin(), firstSet.end());
    std::sort(secondSet.begin(), secondSet.end());

    std::set_symmetric_difference(firstSet.begin(), firstSet.end(), secondSet.begin(), secondSet.end(), std::back_inserter(mergedSet), std::greater<int>());

    for (int i = 0; i < mergedSet.size(); ++i) {
        std::cout << mergedSet[ i] << " ";
    }

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-23 18:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表