\(\mathcal{STL}(\mathcal{Standard\ Template\ Library})\)


  1. \(queue\) (队列):

    这是一种先进先出的数据结构。

    主要操作:

    操作 功能
    \(front()\) 返回队尾元素的值
    \(pop()\) 弹出队头元素
    \(push(x)\) 将 \(x\) 压入队尾
    \(empty()\) 如果队列为空,返回 \(true\)
    \(size()\) 返回当前队列内元素个数

    海港 \(\mathcal{OJ}\)

    这道题主要思路是用一个队列维护时间,再用一个队列记录这个人的国籍

    代码:

    #include <queue>
    #include <cstdio>
    using namespace std;
    const int TIME = 86400;
    int n, Countries_, t, k, x, f[ 100005 ];
    queue <int> Time, PeoPle;
    int main () {
    scanf ("%d", &n);
    for (int i = 1; i <= n; i ++) {
    scanf ("%d %d", &t, &k);
    while (k --) {
    Time.push(t);
    scanf ("%d", &x);
    PeoPle.push(x);
    Countries_ += f[ x ] == 0 ? 1 : 0;//当这个人是该国家唯一到达的人时,国家数加加
    f[ x ] ++;
    }
    while (Time.empty() == false and t - Time.front() >= TIME) {//在每艘船到达后,维护队列,将不满足条件的人弹出队列,并判断该国是否有人在24小时内到达
    Time.pop();
    if (-- f[ PeoPle.front() ] == 0) {
    Countries_ --;
    }
    PeoPle.pop();
    }
    printf ("%d\n", Countries_);
    }
    return 0;
    }

  1. \(stack(\)栈\()\):

    在我看来,栈与队列相当于孪生兄弟,但是队列 \(pop()\) 弹出队头元素,先进先出;栈 \(pop()\) 弹出栈顶元素,先进后出

    主要操作:

    操作 功能
    \(top()\) 返回栈顶元素的值
    \(pop()\) 弹出栈顶元素
    \(push(x)\) 将 \(x\) 压入栈顶
    \(empty()\) 如果栈顶元素为空,返回 \(true\)
    \(size()\) 返回当前栈内元素个数

    例题 表达式括号匹配 \(\mathcal{OJ}\)

    思路:如果当前第i位是右括号, 则判断如果前面有左括号且并未用过。若有,将其弹出栈,否则直接输出 \(NO\)

    代码:

    #include <stack>
    #include <cstdio>
    using namespace std;
    stack <char> s;
    int n;
    char c;
    int main () {
    while (scanf ("%c", &c) != EOF && c != '@') {
    if (c == '(') {//如果c是左括号,将其push进栈,以便于后面判断
    s.push(c);
    }
    else if (c == ')') {
    if (s.empty() == true) {//如果栈为空,即前方无可用左括号,则输出"NO"
    puts("NO");
    return 0;
    }
    s.pop();//若有可用左括号,将左括号弹出,当成已用过
    }
    }
    if (s.empty() == true) {//如果左括号用完,输出"YES"
    puts("YES");
    return 0;
    }
    puts("NO");
    return 0;
    }

  1. \(vector\)(顺序容器,不定长数组):

    和数组差不多,但比数组优越。特征是相当于可分配拓展的数组。它的随机访问、在末端插入和删除快,但在中间插入和删除慢。

    主要操作:

    操作 功能
    \(push\_back(x)\) 在 \(vector\) 的末尾插入变量 \(x\)
    \(pop\)_\(back()\) 去掉 \(vector\) 的末尾数据
    \(front()\) 返回 \(vector\) 第一个元素
    \(begin()\) 返回 \(vector\) 头的指针
    \(end()\) 返回 \(vector\) 最后一个单元 \(+1\) 的指针
    \(clear()\) 清除 \(vector\) 所有数据
    \(empty()\) 如果 \(vector\) 为空,返回 \(true\)
    \(erase(t)\) 删除t位置的数据
    \(erase(Begin, End)\) 删除 \([Begin, End)\) 区间的数据
    \(size()\) 返回当前\(vector\)中数据个数
    \(insert(t, data)\) 在t处插入数据\(data\)

  1. \(map\)(关联容器、有序无重复):

    它提供一对一(其中第一个称为关键字,每个关键字只在 \(map\) 中出现一次,第二个称为该关键字的值)的数据处理能力

    注意:

    1. \(map\) 内部所有的数据都是有序的(红黑树)
    2. 对于迭代器来说,可以修改实值,但不能修改 \(key\)。

    例题 词典 \(\mathcal{OJ}\)

    代码:

    #include <map>
    #include <cstdio>
    #include <iostream>
    using namespace std;
    map <string, string> Dictionary;
    string s, s2;
    char a[ 155 ], b[ 155 ];
    int main () {
    while (getline(cin, s, '\n')) {
    if (s == "") {
    break;
    }
    sscanf(s.c_str(), "%s %s", a, b);
    Dictionary[ b ] = a;
    }
    while (cin >> s) {
    if (Dictionary[ s ] == "\0") {
    puts("eh");
    }
    else {
    cout << Dictionary[ s ] << endl;
    }
    }
    return 0;
    }

  1. \(set\)(关联容器,集合):

    \(set\)是“集合”的意思,\(set\) 中元素都是唯一的,默认情况下会对元素自动进行升序排列,如果需要集合中的元素允许重复那么可以使用 \(multiset\)。

    主要操作:

    操作 功能
    \(begin()\) 返回 \(set\) 中的第一个元素
    \(end()\) 返回 \(set\) 中的最后一个元素
    \(clear()\) 删除 \(set\) 中的所有数据
    \(empty()\) 如果 \(set\) 为空,返回 \(true\)
    \(insert()\) 插入一个元素
    \(erase()\) 删除一个元素
    \(size()\) 返回当前\(set\)中元素个数
    \(count()\) 返回\(set\)中某个值元素的个数
    \(find()\) 返回一个指向被查找到元素的迭代器
    \(lower\_bound()\) 返回指向第一个 \(\geq\) 某个值的元素的迭代器
    \(upper\_bound()\) 返回第一个>某个值的元素的迭代器

    提示:若想让 \(set\) 以降序排序,可使用 \(set<int,\ greater\ < int >\ >\)


  1. \(priority\_queue\)(优先队列)

    定义:任何时刻,队首元素一定是当前队列中优先级最高(优先值最大)的那一个(大根堆),也可以是最小的那一个(小根堆),可以不断向优先队列中添加某个优先级的元素,也可以不断弹出优先级最高的元素,每次操作会自动调整结构,始终保证队首元素的优先级最高。(懵逼 )

    主要操作:

    操作 功能 时间复杂度
    \(push()\) 将 \(x\) 加入优先队列 \(O(log_2{n}),n\) 为元素个数
    \(pop()\) 队首元素出队 \(O(log_2{n}),n\) 为元素个数
    \(top()\) 获得队首元素 \(O(1)\)
    \(empty()\) 如果优先队列为空,返回 \(true\) \(O(1)\)
    \(size()\) 返回 \(priority\_queue\) 内元素的个数 \(O(1)\)

    重点:

    \(priority\_queue<int>\ q\ <=>\ priority\_queue<int,\ vector<int>,\ less<int>\ >\ q\) (升序)

    \(priority\_queue<int,\ vector<int>,\ greater<int>\ >\ q\) (降序)

    例题 合并果子 \(\mathcal{OJ}\)

    代码:

    #include <cstdio>
    #include <queue>
    #include <vector>
    using namespace std;
    priority_queue <int,vector<int>,greater<int> > q;//升序
    int n, a, tot;
    int main () {
    scanf ("%d", &n);
    for (int i = 1; i <= n; i ++) {
    scanf ("%d", &a);
    q.push (a);
    }
    for (int i = 1; i < n; i ++) {//贪心
    int x = q.top ();
    q.pop ();
    x += q.top ();
    q.pop ();
    q.push (x);
    tot += x;
    }
    printf ("%d\n", tot);
    return 0;
    }

STL小结的更多相关文章

  1. C++ STL 知识小结

    qwq...接近联赛,就在这里对STL做一点知识小结吧,因为STL曾经失分很多. 简介 (来自Baidu) STL是Standard Template Library的简称,中文名标准模板库,惠普实验 ...

  2. STL中的算法小结

    ()要运用STL的算法,首先必须包含头文件<algorithm>,某些STL算法用于数值处理,因此被定义于头文件<numeric> ()所有STL算法都被设计用来处理一个或多个 ...

  3. STL中priority_queue小结

    (1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue> (2)在头文件中priority_queue定义如下: namesp ...

  4. STL学习小结

    STL就是Standard Template Library,标准模板库.这可能是一个历史上最令人兴奋的工具的最无聊的术语.从根本上说,STL是一些"容器"的集合,这些" ...

  5. STL set 使用小结

    这是微软帮助文档中对集合(set)的解释: “描述了一个控制变长元素序列的对象(注:set中的key和value是Key类型的,而map中的key和value是一个pair结构中的两个分 量)的模板类 ...

  6. STL容器小结

     1.空间分配器 std::alloc用于容器中内存空间的分配和释放,以及分配内存的管理.construct().destroy()等全局函数用于为对象的构造和析构. 2.迭代器和trains 迭代器 ...

  7. 小结:STL

    概要: c++的stl是个神奇的东西,需要好好学习. 技巧及注意: lower_bound是第一个大于等于要查找值 upper_bound是第一个大于要查找的值 stl中的容器中的比较几乎全都用< ...

  8. STL 中priority_queue小结

    (1)为了运用priority_queue,你必须包含头文件<queue>:#include<queue>    (2)在头文件中priority_queue定义如下: nam ...

  9. HZNU-ACM寒假集训Day1小结 STL 并查集

    常用STL 1.优先队列 priority_queue 内部是用堆(heap)实现的 priority_queue<int> pq; 默认为一个“越小的整数优先级越低的优先队列” 对于一些 ...

随机推荐

  1. element ui中表格table翻页记忆勾选状态

    <el-table ref="multipleTable" :data="datalist" style="width:100%" @ ...

  2. MySQL技术内幕InnoDB存储引擎(三)——文件相关

    构成MySQL数据库和InnoDB存储引擎表的文件类型有: 参数文件:MySQL实例运行时需要的参数就是存储在这里. 日志文件:用来记录MySQL实例对某种条件做出响应时写入的文件. socket文件 ...

  3. 傲视Kubernetes(二):Docker镜像搭建与本地Kubernetes环境搭建

    主要内容: 1.Docker与Kubernetes的关系 2.SpringBoot微服务的Docker镜像创建 3.Kubernetes本地环境搭建 一.Docker与Kubernetes的关系 在说 ...

  4. Salesforce 系列(一):云服务和 Salesforce 理念简介

    本系列文章系笔者在 Salesforce 开发过程中的些许总结与心得,旨在记录自己的成长,以及为对 Salesforce 感兴趣的小伙伴提供一些帮助,如有疏漏,还望多多包涵 ~ 云服务 云服务,也称云 ...

  5. Windows版 charles安装证书抓包网页HTTPS

    1.在Charles官网https://www.charlesproxy.com/download/下载,我这边下载的是免费体验版的. 2.安装好以后打开,配置Charles证书:选择 help--S ...

  6. 学好Spark/Kafka必须要掌握的Scala技术点(一)变量、表达式、循环、Option、方法和函数,数组、映射、元组、集合

    前言 Scala是以JVM为运行环境的面向对象的函数式编程语言,它可以直接访问Java类库并且与Java框架进行交互操作.正如之前所介绍,Spark是用Scala语言编写的,Kafka server端 ...

  7. GC agent的安装和卸载

    一.GC agent安装 下面介绍GC agent的push和pull两种安装方法 1.push(推送)安装GC agent方法 1).打开EMGC home page:https://even.or ...

  8. Linux(CentOS7)安装Nginx(附简单配置)

    1. 安装make yum -y install gcc automake autoconf libtool make 2. 安装gcc yum -y install gcc gcc-c++ 3. 安 ...

  9. adb devices查看不到Android模拟器的设备

    1.先开启模拟器,后执行adb devices命令: List of devices attached 2.找到SDK的安装目录下platform-tools文件夹下adb.exe文件,将其复制到桌面 ...

  10. IDEA将Java Web项目打war包

    准备工作 1.IntelliJ IDEA开发工具 2.可以正常运行的Java Web项目 打war包流程 1.使用快捷键Ctrl+Alt+Shift+s 或者 鼠标点击选中项目名按F4 打开 Proj ...