酷代码 AI
菜单
服务商

给定含有 n 个整数的序列,要求对这个序列进行去重操作。所谓去重,是指对这个序列中每个重复出现的数,只保留该数第一次出现的位置,删除其余位置。 输入 输入包含两行: 第一行包含一个正整数 n(1 ≤ n ≤ 20000),表示第二行序列中数字的个数。 第二行包含 n 个整数,整数之间以一个空格分开。每个整数大于等于 1、小于等于 5000。 输出 输出只有一行,按照输入的顺序输出其中不重复的数字,整数之间用一个空格分开。 c++

```cpp #include <iostream> #include <unordered_set> #include <vector> using namespace std; int main() { int n; cin >> n; vector<int> numbers(n); unordered_set<int> unique_numbers; vector<int> result; for (int i = 0; i < n; ++i) { cin >> numbers[i]; } for (int num : numbers) { // 检查该数是否已经在集合中 if (unique_numbers.find(num) == unique_numbers.end()) { // 若不在集合中,添加到集合和结果向量中 unique_numbers.insert(num); result.push_back(num); } } for (int i = 0; i < result.size(); ++i) { if (i != 0) { cout << " "; } cout << result[i]; } cout << endl; return 0; } ``` [2026-02-07 21:05:21 | AI问答 | 234点数解答]

相关提问
发财导航,免费问AI
实用工具查看更多