• 常用STL:

    • vector

      • 变长数组,倍增的思想
      • 初始化:
      //初始化
      vector<int> a;
      vector<int> a(n);
      vector<int> a[n];
      vector<int> a(n, 0);//长度为n,值为0
      • 操作:
      size() //返回元素个数
      empty() //返回是否为空
      clear() //清空
      front()/back() //返回第一个/最后一个元素
      push_back()/pop_back() //在尾端插入元素/删除元素
      begin()/end() //迭代器
      [] //随机访问
      • 遍历:
      for(int i = 0; i < a.size(); ++ i)
      for(vector<int>::iterator/*auto*/ i = a.begin(); i != a.end(); ++ i)
      for(auto x : a)
      • 黑科技:

        • 支持比较运算,按字典序比较
    • pair

      • 二元组
      • 初始化:
      pair<T, T> p;
      pair<T, pair<T, T>> p;
      p = make_pair(a, b);
      p = {a, b};
      p.first/p.second //第一个元素/第二个元素
      • 黑科技:

        • 也支持比较运算
        • 以first为第一关键字,以second为第二关键字
    • string

      • 字符串
      • 初始化:
      string a = "adfb";
      a += "adf";
      a += 'c';
      • 操作:
      size()/length() //返回字符串长度
      empty() //返回是否为空
      clear() //清空
      substr() //求子串
      a.substr(st, len) //从下标st开始长度为len的子串
      a.substr(st) //从st开始到结尾的子串
      c_str() //返回字符串地址
      //printf()无法输出string,但是可以printf("%s", a.c_str);
    • queue

      • queue

        • 队列
        • 初始化:同数组
        • 操作:
        size()
        empty()
        push() //想队尾插入元素
        pop() //弹出队头元素
        front() //返回队头元素
        back() //返回队尾元素
        //队列没有clear()函数
      • priority_queue
        • 优先队列(堆)
        • 初始化:
        priority_queue<int> heap; //堆默认为大根堆
        heap.push(-x); //将数反号实现小根堆
        priority_queue<int, vector<int>, greater<int> > heap //直接定义小根堆
        • 操作:
        push() //插入一个元素
        top() //返回堆顶元素
        pop() //弹出堆顶元素
    • stack

      • 初始化:同数组
      • 操作:
      size()
      empty()
      push() //向栈顶插入元素
      top() //返回栈顶元素
      pop() //弹出栈顶元素
    • deque

      • 双端队列
      • 初始化:
      • 操作:
      size()
      empty()
      clear()
      front()
      back()
      push_back()/pop_back()
      push_front()/pop_front()
      begin()/end()
      []
      //操作多效率低
    • set

      • set

        • 集合:无重复元素
        • 基于平衡二叉树
        • 操作:
        size()
        empty()
        clear()
        insert() //插入一个数
        find() // 查找一个数
        count() //返回某个数的个数
        erase() //输入一个数x,删除所有x;输入一个迭代器,删除这个迭代器
        lower_bound() //返回大于等于x的最小的数的迭代器
        upper_bound() //返回大于x的最小的数的迭代器
        //增删查改时间复杂度为log(n)
      • multiset
        • 可以有重复元素
        • 操作:同set
      • 以下unoder 都不支持排序有关操作,因为是无序的,不支持lower_bound/upper_bound ,但是增删改查的时间复杂度为O(1),不支持迭代器的加减
      • unordered_set
      • unordered_multiset
    • map

      • map

        • 基于平衡二叉树
        • 元素是pair
      • multimap
        • 操作:
        insert() //插入的数是一个pair
        erase() //输入的参数是pair或者迭代器
        find() map<string, int> a;
        a["adf"] = 1; //支持随机插入/访问,时间复杂度为log(n)
        lower_bound()/upper_bound()
        //增删查改时间复杂度为log(n)
      • 以下unoder 都不支持排序有关操作,因为是无序的,不支持lower_bound/upper_bound ,但是增删改查的时间复杂度为O(1),不支持迭代器的加减
      • unordered_map
      • unordered_multimap
    • bitset

      • 压位

        • bool 类型位一个字节,8位
        • 如:压位将bool 占用内存压缩1/8,使bool类型只占一个二进制位
        • bitset 相当于一个二进制数组,数组里存0/1,一个数组元素占1个二进制位
      • 初始化:
      bitset<10000> s;
      • 操作:
      ~, &, |, ^
      >>, <<
      ==, !=
      []
      count() //返回有多少1
      any() //判断是否至少有一个1
      none() //判断是否全为0
      set() //把所有位置成1
      set(k, v) //将第k位变成v
      reset() //把所有位变成0
      flip() //等价于~
      flip(k) //把第k位取反

常用c++ STL 汇总的更多相关文章

  1. 常用 Gulp 插件汇总 —— 基于 Gulp 的前端集成解决方案(三)

    前两篇文章讨论了 Gulp 的安装部署及基本概念,借助于 Gulp 强大的 插件生态 可以完成很多常见的和不常见的任务.本文主要汇总常用的 Gulp 插件及其基本使用,需要读者对 Gulp 有一个基本 ...

  2. 常用的STL查找算法

    常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...

  3. 常用Git命令汇总

    常用Git命令汇总 跟着R哥来到了新公司(一个从硬件向互联网转型中的公司),新公司以前的代码基本是使用SVN做版本控制,甚至有些代码没有做版本控制,所以R哥叫HG做了一次Git分享,准备把公司所有的代 ...

  4. Mysql中常用的函数汇总

    Mysql中常用的函数汇总: 一.数学函数abs(x) 返回x的绝对值bin(x) 返回x的二进制(oct返回八进制,hex返回十六进制)ceiling(x) 返回大于x的最小整数值exp(x) 返回 ...

  5. ROS(indigo)机器人操作系统学习资料和常用功能包汇总整理(ubuntu14.04LTS)

    ROS(indigo)机器人操作系统学习资料和常用功能包汇总整理(ubuntu14.04LTS) 1. 网站资源: ROSwiki官网:http://wiki.ros.org/cn GitHub    ...

  6. React Native常用第三方组件汇总--史上最全 之一

    React Native 项目常用第三方组件汇总: react-native-animatable 动画 react-native-carousel 轮播 react-native-countdown ...

  7. React Native常用第三方组件汇总--史上最全[转]

    本文出处: http://blog.csdn.net/chichengjunma/article/details/52920137 React Native 项目常用第三方组件汇总: react-na ...

  8. 刷题常用的STL容器总结

    本文归纳总结刷题常用到STL容器以及一些标准算法,主要包括: string.vector.map.pair.unordered_map.set.queue.priority_queue.stack,以 ...

  9. js如何操作表格(常用属性方法汇总)

    js如何操作表格(常用属性方法汇总) 一.总结 一句话总结: 二.表格相关的属性和方法 1.1 Table 对象集合 cells[] 返回包含表格中所有单元格的一个数组. 语法:tableObject ...

  10. python-Redis模块常用的方法汇总

    Redes模块常用的方法汇总 一.创建建Redis对象 1.直接使用 import redis r = redis.Redis(host='127.0.0.1', port=6379) 2.连接池使用 ...

随机推荐

  1. SPN在域环境的应用

    windows域为了集中资源,有效地对资源访问控制权限进行细粒度分配,提高网络资源统一分配的管理.域内的每种资源分配了不同的服务主体名称(SERVICE Pricipal Name,SPN) 相关概念 ...

  2. 【Redis】常用命令介绍

    一.Redis常用基本命令 官方文档:https://redis.io/commands/ 参考文档:http://redisdoc.com/ #可以使用help命令查看各redis命令用法[root ...

  3. 推荐一个.Net Core开发的Websocket群聊、私聊的开源项目

    今天给大家推荐一个使用Websocket协议实现的.高性能即时聊天组件,可用于群聊.好友聊天.游戏直播等场景. 项目简介 这是一个基于.Net Core开发的.简单.高性能的通讯组件,支持点对点发送. ...

  4. 2021-11-25:给定两个字符串s1和s2,返回在s1中有多少个子串等于s2。来自美团。

    2021-11-25:给定两个字符串s1和s2,返回在s1中有多少个子串等于s2.来自美团. 答案2021-11-25: 改写kmp算法. next数组多求一位. 比如:str2 = aaaa, 那么 ...

  5. 【汇编】老师太hun

    老师只是随手发实验项目卡,从未提过实验报告的事情 可是 他却要在 复习周 一下子 收6次 实验报告 也不发资料,不说每次的时间点,不讲实验 这人心中有 学生 吗? 上课发 上个班直播的录播 一节课就发 ...

  6. WPF入门教程系列二十四——DataGrid使用示例(2)

    WPF入门教程系列目录 WPF入门教程系列二--Application介绍 WPF入门教程系列三--Application介绍(续) WPF入门教程系列四--Dispatcher介绍 WPF入门教程系 ...

  7. java开发学习框架

    Java基础 1.1. Java简介与安装 1.2. Java基本语法 1.3. 数据类型与变量 1.4. 运算符与表达式 1.5. 流程控制(分支与循环) 1.6. 数组 面向对象编程 2.1. 类 ...

  8. P1751 贪吃虫 题解

    题意: 题目传送门 在一棵 n 个结点的树上,有 k 个贪吃虫去吃食物. 每个贪吃虫都走到达食物的唯一路径. 当一条贪吃虫通向食物的道路上有另一条贪吃虫,则较远的那只停止移动. 多条贪吃虫要进入同一节 ...

  9. Hive执行计划之什么是hiveSQL向量化模式及优化详解

    Hive开启向量化模式也是hiveSQL优化方法中的一种,可以提升hive查询速率,也叫hive矢量化. 问题1:那么什么是hive向量化模式呢? 问题2:hive向量化什么情况下可以被使用,或者说它 ...

  10. c++中vector容器的用法

    C语言中const关键字是constant的缩写,通常翻译为常量.常数等,它可以修饰变量.数组.指针.函数参数. vector 是向量类型,它可以容纳许多类型的数据,如若干个整数,所以称其为容器.ve ...