题解 | 明明的随机数
#include <bits/stdc++.h>
#include <vector>
using namespace std;
int main() {
int n,a;
cin>>n;
set<int> s;
for(int i=0;i<n;i++){
cin>>a;
s.insert(a);
}
for(auto it:s){
cout<<it<<endl;
}
return 0;
}
// 64 位输出请用 printf("%lld")
善用stl
1. std::set 的定义
std::set 是一个 关联式容器,用于存储 唯一的、排好序的元素。它会在插入元素时自动去重,并将元素按照升序(默认)或指定顺序排序。
2.std::set 的特点
底层实现:std::set 的底层是基于 红黑树 的有序二叉搜索树。
元素唯一性:插入的重复元素会被忽略。
有序性:插入的元素会自动按照从小到大的顺序存储
3. for(auto it : s)
- for (auto it : s)这里的 it 是一个循环变量,用来接收 set<int> 容器 s 中的每个元素的值。auto 是 C++ 的自动类型推导关键字,在这里,编译器会推导 it 的类型为 int(因为 set<int> 的元素是 int 类型)。s 是 std::set 容器,表示从其中依次取出每个元素。
- 循环过程:for 循环会从 s 中依次取出每一个元素(按照 std::set 的升序排列规则),将其赋值给 it,然后执行循环体内的语句。
