题目描述 给N个0 ~ 32767内的随机数(含边界0和32767),要求进行排序并且把重复的去掉然后输出 输入描述 输入文件包含2行 第1行为1个正整数,表示所生成的随机数的个数N。 第2行有 N 个用空格隔开的整数,为所产生的随机数。 输出描述 输出文件也是2行,第1行为1个正整数 M,表示不相同的随机数的个数。 第2行为 M 个用空格隔开的整数,为从小到大排好序且不相同的随机数。 样例1 输入 10 20 40 32 67 40 20 89 300 400 15 输出 8 15 20 32 40 67 89 300 400 C++
时间: 2024-04-15 10:25:03 浏览: 99
您好!对于给定的随机数,您可以使用以下C++代码进行排序并去重:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
#include <unordered_set>
int main() {
int N;
std::cin >> N; // 读取随机数的个数
std::vector<int> nums(N);
for (int i = 0; i < N; i++) {
std::cin >> nums[i]; // 读取随机数
}
// 排序
std::sort(nums.begin(), nums.end());
// 去重
std::unordered_set<int> uniqueNums(nums.begin(), nums.end());
// 输出结果
std::cout << uniqueNums.size() << std::endl;
for (int num : uniqueNums) {
std::cout << num << " ";
}
std::cout << std::endl;
return 0;
}
```
您可以将输入数据保存在一个文本文件中,如`input.txt`,然后使用以下命令编译和运行程序:
```shell
g++ -o output your_file.cpp
./output < input.txt > output.txt
```
这将会在`output.txt`文件中输出排序并去重后的随机数。
阅读全文