题解 | 明明的随机数

#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,然后执行循环体内的语句。
全部评论

相关推荐

03-09 20:32
运营
牛客972656413号:成绩管理系统会不会有点太。。。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务