Leetcode刷题笔记-标准库


标准库

栈 stack

  1. push() 压入栈
  2. pop() 弹出首元素
  3. top() 返回首元素

队列 queue

  1. push() 压入队列
  2. pop() 弹出队列头元素
  3. front() 获取队列头元素,注意这里不是top

堆 priority_queue

  1. 默认最大堆
  2. 最小堆 priority_queue<int, vector, greater>
  3. 找第k大元素:转换思路,维护k个元素的最小堆,堆底为最大,堆顶为第k大

字符串 string

  1. substr(起始下标, 子串长度) 获取子串
  2. insert(插入位置下标,字符串) 在该位置前插入字符串
  3. append() 拼接字符串
  4. append(个数,内容) 拼接多个字符串
  5. 重载+ 拼接字符/字符串
  6. stoi()/stod() 字符串转整型/浮点型
  7. to_string() 整型/浮点型转字符串

字符 char

  1. 字符转整型 int(字符 - ‘0’)
  2. 整型转字符 char(整型 + ‘0’)

容器 vector

  1. 初始化 vector new_vector(5, 0) 5个元素均为0
  2. 也可以直接用另一个vector变量的迭代器初始化,注意右区间迭代器是末端位置的下一个位置
  3. pop_back() 弹出最末尾元素
  4. insert(iterator loc, const TYPE &val) 插入,也可以用迭代器插入另一个vector变量的一个区间

映射 map

  1. 三种:map, multimap, unordered_map,前两者的实现为红黑树,unordered_set的底层实现是哈希表
  2. 键:.first,值:.second
  3. 插入元素:insert/直接通过[]
  4. 查找键值:find(),若不存在则返回.end(),否则返回指向该映射的迭代器
  5. 删除映射:erase,参数可以是键/迭代器
  6. 计数:count

集合 set

  1. 三种:set, multiset, unordered_set
  2. find() 查找,同map
  3. count() 计数
  4. set和multiset有序,和map与multimap一样都默认为升序排列,如默认为set<int, less< int>> 为升序,可以设置降序为set<int, greater< int>>
  5. 自定义排序方式(降序排列):
    set<int, cmp> my_set;
    struct cmp {
    	bool operator() (int& a, int& b) {return a > b; }
    }
    

排序 sort

  1. sort(.begin(), .end()) 快速排序,默认升序
  2. sort(.begin(), .end(), [] (int a, int b) {return a > b;}) 自定义排序方式,降序

Tips

  1. INT32_MAX
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值