【STL】一文拿下所有C++stl

目录

1.vector, 变长数组,倍增的思想

2.pair<int,int>

3.string,字符串

4.queue, 队列

5.priority_queue, 优先队列,默认是大根堆

6.stack, 栈

7.deque, 双端队列

8.set, map, multiset, multimap, 基于平衡二叉树(红黑树),动态维护有序序列

    set/multiset

    map/multimap

    unordered_set, unordered_map, unordered_multiset, unordered_multimap, 哈希表

9.bitset, 圧位


1.vector, 变长数组,倍增的思想

  1.  size()  返回元素个数
  2.  empty()  返回是否为空
  3. clear()  清空
  4. front()/back()
  5.push_back()/pop_back()
  6. begin()/end()
  7. []
  8.支持比较运算,按字典序

#include <vector>

//初始化
vector <int> a;
vector <int> a(10);      //长度为10的vector
vector <int> a(10,3);   //10个数,每个都为3
vector <int> a[10];      //定义10个vector数组

//
a.size();//返回个数
a.empty();//判断是否空
a.clear();//清空

//
a.front();//返回第一个数
a.back();//返回最后一个数

//插入,删除
a.push_back();//向最后插入一个数
a.pop_back();//把最后一个数删掉
//例子
for(int i=0;i<10;i++)a.push_back(i);

//迭代器
a.begin()//vector第0个数
a.end()//vector最后一个数的后边一个数    

//遍历
//法一:正常数组遍历
//法二:迭代器
      for(auto i=a.begin();i!=a.end();i++) cout<<*i<<' ';  //vector<int>::iterator可写为auto
//法三: 范围遍历
      for(auto x :a)cout<<x<<' ';
     

//支持比较运算
vector<int>a(3,4),b(4,3);
if(a<b)puts("YES");

2.pair<int, int>

当某个东西有两个不同的属性(三个)可以用pair存储,若排序则把要排序的属性放first,不排序 的关键词放second
   1. first, 第一个元素
   2.second, 第二个元素
   3.支持比较运算,以first为第一关键字,以second为第二关键字(字典序)

#include <vector>

int main(){

pair <int ,string>p;

//取第一,二个元素
p.first;
p.second;//取第二个元素

//初始化
p=make_pair(10,"wzf");//法一
p=(10,"wzf");         //法二

//三个属性时
pair<int,pair<int,int>>p;

}

3.string,字符串

   1. size()/length()  返回字符串长度
   2. empty()
   3. clear()
   4. substr(起始下标,(子串长度))  返回子串
   5. c_str()  返回字符串所在字符数组的起始地址

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;
int main(){

//添加操作
string a="wzf";
a+="fzw";
a+='a';

//从第一个字符开始,输出长度为的10字符
cout<<a.substr(0,10)<<endl;

cout<<a.substr(2)<<endl;//省略第二个参数,此例子则输出从第三个字符全部串

//输出
cout<<a<<endl;//法一
printf("%s\n",a.c_str());//法二,返回起始地址


}

4.queue, 队列

先进先出

   1. size()
   2. empty()
   3. push()  向队尾插入一个元素
   4. front()  返回队头元素
   5. back()  返回队尾元素
   6. pop()  弹出队头元素

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;
int main(){

//初始化
queue<int>q;

//清空
q=queue<int>();


}

5.priority_queue, 优先队列,默认是大根堆

    1.size()
    2.empty()
    3.push()  插入一个元素
    4. top()  返回堆顶元素
    5.pop()  弹出堆顶元素
    6.定义成小根堆的方式:priority_queue<int, vector<int>, greater<int>> q;

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <queue>

using namespace std;
int main(){

//初始化
priority_queue<int> heap;

//默认大根堆,改为小根堆
heap.push(-x);//法一:直接插入负数
priority_queue<int, vector<int>, greater<int>> q;//法二:定义时改变

}

6.stack, 栈

    size()
    empty()
    push()  向栈顶插入一个元素
    top()  返回栈顶元素
    pop()  弹出栈顶元素

7.deque, 双端队列


    size()
    empty()
    clear()
    front()/back()
    push_back()/pop_back()
    push_front()/pop_front()
    begin()/end()
    []

8.set, map, multiset, multimap, 基于平衡二叉树(红黑树),动态维护有序序列


    size()
    empty()
    clear()
    begin()/end()
    ++, -- 返回前驱和后继,时间复杂度 O(logn)

    set/multiset


        insert()  插入一个数
        find()  查找一个数
        count()  返回某一个数的个数
        erase()
            (1) 输入是一个数x,删除所有x   O(k + logn)
            (2) 输入一个迭代器,删除这个迭代器
        lower_bound()/upper_bound()
            lower_bound(x)  返回大于等于x的最小的数的迭代器
            upper_bound(x)  返回大于x的最小的数的迭代器


    map/multimap


        insert()  插入的数是一个pair
        erase()  输入的参数是pair或者迭代器
        find()
        []  注意multimap不支持此操作。 时间复杂度是 O(logn)
        lower_bound()/upper_bound()

    unordered_set, unordered_map, unordered_multiset, unordered_multimap, 哈希表


    和上面类似,增删改查的时间复杂度是 O(1)
    不支持 lower_bound()/upper_bound(), 迭代器的++,--

9.bitset, 圧位


    bitset<10000> s;
    ~, &, |, ^
    >>, <<
    ==, !=
    []

    count()  返回有多少个1

    any()  判断是否至少有一个1
    none()  判断是否全为0

    set()  把所有位置成1
    set(k, v)  将第k位变成v
    reset()  把所有位变成0
    flip()  等价于~
    flip(k) 把第k位取反

//课程剩余1.46.15

  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

漆黑の莫莫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值