yangzhixiaohuli 发表于 2023-11-14 13:18:26

求助一下

【问题描述】

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

【输入形式】

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

【输出形式】

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

【样例输入】

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

87 32 10 9 8 7 4 2 -6

这题用C++怎么做

isdkz 发表于 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;
}
页: [1]
查看完整版本: 求助一下