NowCode:HJ3 明明的随机数

题目:明明的随机数

描述

明明生成了N个1到500之间的随机整数。请你删去其中重复的数字,即相同的数字只保留一个,把其余相同的数去掉,然后再把这些数从小到大排序,按照排好的顺序输出。

数据范围:1≤n≤1000 ,输入的数字大小满足 1≤val≤500

输入描述:

第一行先输入随机整数的个数 N 。 接下来的 N 行每行输入一个整数,代表明明生成的随机数。 具体格式可以参考下面的”示例”。

输出描述:

输出多行,表示输入数据处理后的结果

示例1

输入:

1
2
3
4
3
2
2
1

输出:

1
2
1
2

说明:

1
2
3
4
5
6
7
8
输入解释:
第一个数字是3,也即这个小样例的N=3,说明用计算机生成了3个1到500之间的随机整数,接下来每行一个随机数字,共3行,也即这3个随机数字为:
2
2
1
所以样例的输出为:
1
2

题解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
#include <set>
using namespace std;

int main() {
set<int> order;
int num = 0;
int input = 0;
cin >> num;
while (num--) {
cin >> input;
order.emplace(input);
}
for (auto it = order.begin(); it != order.end(); it++) {
cout << *it <<endl;
}
}

思路

使用set容器去重

此题简单