首页 > 其他分享 > 关于STL容器的简单总结

关于STL容器的简单总结

时间:2023-05-28 10:11:10浏览次数:43  
标签:总结 容器 end 迭代 STL rit 元素 bt vec

关于STL容器的简单总结

1、结构体中重载运算符的示例

//结构体小于符号的重载
struct buf { 
   int a,b;
   bool operator < (const buf& c1) const {  //注意:第二个const一定不能少
   return a<c1.a;
   }
};
//或
struct foo {
    int a,b;
};
bool operator < (const foo &x, const foo &y)
{return x.a < y.a;}

2、队列(queue)

#include <queue>
queue<int>a;    //定义 
a.push(x);      //压入 
a.pop();      //弹出 
a.size();   //取大小 
a.front();    //访问队首元素 
a.back();     //访问队尾元素 
a.empty();    //判断队列是否为空

3、优先队列(priority_queue)

#include <queue>
priority_queue<int,vector<int>,greater<int> > c;      //定义从小到大的int类型的优先队列
priority_queue<int> c;                                //定义从大到小的int类型的优先队列 
c.push();        //压入 
c.pop();         //弹出队首元素 
c.top();         //访问队首元素 
c.empty();       //判断队列是否为空
//如是结构体必须重载'<' 

4、双端队列(deque)

#include <deque>
deque <int> b;    //定义双端队列 
b.push_front(x); //在队首压入元素 
b.push_back(x);  //在队尾压入元素 
b.pop_front();   //弹出队首元素 
b.pop_back();    //弹出队尾元素 
b.size();        //取大小 
b.back();        //访问队尾元素
b.front();       //访问队首元素 
b.empty();       //判断队列是否为空
//可用[]访问

5、栈(stack)

#include <stack>
stack<int> d;    //定义 
d.push(x);       //压入元素 
d.pop();         //弹出栈顶元素 
d.top();         //访问栈顶元素 
d.size();        //取大小 
d.empty();       //判断栈是否为空

6、 集合(set)

#include <set>
set<int> e;
e.insert(i);     //插入元素 
e.erase(i);      //删除值为i的元素 
e.count(i);      //查看值为i的元素是否存在 
e.empty();       //判断set是否为空
set<int>:: iterator rit;        //定义迭代器 
rit = (e.insert(j)).first    //返回插入后元素对应的迭代器
rit=e.find(i);       //返回值为i的元素的迭代器,如果没找到返回的是e.end()
rit=e.lower_bound(i)  //返回值大于等于i的第一个元素的迭代器, 如果没有大于等于i的元素返回e.end()
rit=e.upper_bound(i)  //返回值大于i的第一个元素的迭代器, 如果没有大于i的元素返回e.end()
for(rit=e.begin();rit!=e.end();rit++)   //正序遍历,值为*rit
set<int>::reverse_iterator rit;         //反向遍历的迭代器 
for(rit=e.rbegin();rit!=e.rend();rit++) //反向遍历必须这么写 
注: 不能直接写e.erase(e.rbegin());
//如使用结构体,必须重载< 或写仿函数

7、可重集(multiset)

#include <set>
multiset<int> e;
e.insert(i);     //插入元素 
e.erase(i);      //删除所有值为i的元素 
e.erase(e.find(i)) //删除一个值为i的元素
e.count(i);      //统计值为i的元素的数量
e.empty();       //判断multiset是否为空
multiset<int>:: iterator rit;        //定义迭代器 
rit = (e.insert(j)).first    //返回插入后元素对应的迭代器
rit=e.find(i);       //返回第一个值为i的元素的迭代器,如果没找到返回的是e.end()
rit=e.lower_bound(i)  //返回值大于等于i的第一个元素的迭代器, 如果没有大于等于i的元素返回e.end()
rit=e.upper_bound(i)  //返回值大于i的第一个元素的迭代器, 如果没有大于i的元素返回e.end()
for(rit=e.begin();rit!=e.end();rit++)   //正序遍历,值为*rit
set<int>::reverse_iterator rit;         //反向遍历的迭代器 
for(rit=e.rbegin();rit!=e.rend();rit++) //反向遍历必须这么写 
//如使用结构体,必须重载< 或写仿函数
注: 如希望用多种不同排序方式对set/multiset内元素进行排序, 则应该重载运算符, 写成仿函数形式:

struct t {
    int a, b, c;
};
struct cmp1
{
    bool operator () (const t &x, const t &y)
    {return x.a < y.a;}
};
struct cmp2
{
    bool operator () (const t &x, const t &y)
    {return x.b < y.b;}
};
struct cmp3
{
    bool operator () (const t &x, const t &y)
    {return x.c < y.c;}
};
set <t, cmp1> st;
set <t, cmp2> st2;
set <t, cmp3> st3;

8、map

#include <map>
map<string,int> f; //定义一个map,其中string是键值(就像一个人的名字一样)的类型,int是值的类型,可以随便换。 键值需要重载 <。
f[s]=d;  //把一个键值为s,值为d的元素 插入到此map中或覆盖原有映射(因为map重载了[]所以可以直接这样写) 
f.count(s); //统计键值为s的元素的个数,因为在map中键值是排好序的集合,所以count()的返回值不是1就是0 
f.erase(s);            //删掉键值是s的元素 
f.size();              //取大小
f.empty();             //判断map是否为空
map<string,int>:: iterator rit;    //定义map的迭代器 ,遍历的时候可能会用到 
rit=f.find(s);                     //返回键值为s的元素的迭代器 
rit->second;            //迭代器为s映射的值,如把second改成first则是s 
//查询可以直接用[] 
//map就像一个完美的哈希表,但内部由红黑树实现, 因此操作复杂度均为O(log(n)),有了map妈妈再也不用担心查找数据了!

9、vector

#include <vector>
vector <int> vec;             //定义一个vector, 内部元素类型为int。
vector <int>::iterator it;    //定义vector<int> 的迭代器
vec.push_back(i)              //向vec后面加入元素i
vec.push_front(i)             //向vec前面加入元素i
vec.begin()                   //返回vec的第一个元素对应的迭代器, 如果为空返回vec.end()
vec.size()                    //返回vector内的元素个数
vec.erase(it)                 //删除it对应元素, 同时后面的元素整体前移一位。 注: 复杂度为O(N)
vec.clear()                   //清空vec, 但不释放内存
vector <int>().swap(vec)      //清空vec并释放内存(若卡内存,多组数据的题推荐这样清零)

10、sort()

#include <algorithm>
vector <int> vec;
sort(vec.begin(), vec.end());//vector的sort方式
int a[105];
sort(a, a + 105);//将整个a数组从小到大排序
double b[1005];
bool cmp (double c, double d)//自定义排序方法
{return c > d;}
sort(b + 1, b + 1 + 1000, cmp)//将b[1] ~ b[1000]的元素从大到小排序

11、二分查找

注:lower_bound和upper_bound  使用前提均为原序列有序!

#include <algorithm>
int a[1005], pos;
int *b;
b = lower_bound(a + 1, a + 1001, i)   //返回a[1] ~ a[1000]第一个大于等于i的元素的指针, 若没有则返回a[1001]的指针
b = upper_bound(a + 1, a + 1001, i)   //返回a[1] ~ a[1000]第一个大于i的元素的指针, 若没有则返回a[1001]的指针
pos = b - a;                          //得到其下标
vector <int> vec;
vector <int>::iterator it;            
it = lower_bound(vec.begin(), vec.end(), i)  //返回vec中第一个大于等于i的元素的迭代器, 若没有则返回vec.end()
it = upper_bound(vec.begin(), vec.end(), i)  //返回vec中第一个大于i的元素的迭代器, 若没有则返回vec.end()
set <int> st;
set <int>::iterator it;
it = st.lower_bound(st.begin(), st.end(), i)  //返回st中第一个大于等于i的元素的迭代器, 若没有则返回st.end()
it = st.lower_bound(st.begin(), st.end(), i)  //返回st中第一个大于i的元素的迭代器, 若没有则返回st.end()

12、reverse()

#include <algorithm>
int a[105];
reverse(a + 1, a + 1 + 100);          //将a[1] ~ a[100]及其之间的元素前后翻转
vector <int> vec;
reverse(vec.begin(), vec.end())       //前后翻转整个vec里面的元素

13、bitset

//bitset可以当bool数组用, 但其内部为unsigned int压位而成, 支持左右移, 赋值, 清零等操作。 01背包用bitset优化可以做到O(N^2/32)
#include <bitset>
bitset <1005> bt;                       //声明一个大小为1005的bitset
bt[0] = 1;                              //将bt[0]设为1
int a;
a = bt.count();                         //返回bt中1的个数
bt.reset();                             //将bt所有位清零
bt.set();                               //将bt所有位设为1
bt.flip();                              //将bt所有位异或1
bt.flip(i);                             //将bt第i位翻转
bt = bt | (bt << 1)                     //将bt的第i位与第i + 1位取或, 复杂度为O(N/32)
bt = bt ^ (bt >> 2)                     //将bt的第i位和第i - 2位异或, 复杂度为O(N/32)

14、__builtin_系列

//以下函数复杂度均为O(1)
int a = __builtin_popcount(233)              //返回233二进制位上1的个数
int b = __builtin_ffs(666)                   //返回666二进制位从低向高第一个1的位置
int c = __builtin_ctz(19260817)              //返回19260817二进制位后缀0的个数
//注: 以上函数所传变量默认均为unsigned int, 若要传long long 请在后面加上"ll"。
例如: int d = __builtin_popcountll(1000000000000ll);
转自http://ybt.ssoier.cn:8087

标签:总结,容器,end,迭代,STL,rit,元素,bt,vec
From: https://www.cnblogs.com/chiyun010/p/17437847.html

相关文章

  • 2023/5/27每日总结
       今天,周六,写了三章的数据库作业,还复习了两章的内容,规范化理论与数据库保护;这里把知识点目录写一下:规范化理论:完全函数依赖,部分函数依赖,传递函数依赖,候选码,主码,主属性,非主属性,外码,第一范式,第二范式,第三范式,转化为第二范式,第三范式。数据库保护:事务,事务特点,事务并发性操......
  • kubeadm极速部署Kubernetes,教你如何轻松处理容器运行瓶颈(Docker丨容器化技术丨DevOps
    kubeadm极速部署Kubernetes1.25版本集群前言随着Kubernetes的普及,快速部署和管理Kubernetes集群已成为容器领域的关键技能之一。本文将介绍使用kubeadm工具部署Kubernetes集群的方法,为您提供一个简单且高效的解决方案。不再需要自行构建集群,通过使用本文的方法,您将能够在最短的时......
  • 个人总结1500字
         这学期的软件工程已经接近尾声,接下来,下面是我对这学期的总结。     上学期,javaweb速成,跟着博客和教程自己弄成一套javaweb,但是没太系统地去学习那个东西,我在寒假,学了学javaweb,在这学期开课中多次用到学到技术,这学期虽然学到不多把,但是总归还是有些收......
  • 大二上个人总结
    转眼间一学期又过去了,在这里做出自己的个人总结。首先回顾自己第一周定的计划:每天拿出至少半小时学习这门课,我并没有很好的执行,没有坚持每天都学半小时。但没走学习的次数和时间还是不少的。另外,按质按量完成布置的任务,这个完成的还算可以,一次个人作业,完成的比较满意,一次两人作业......
  • Beta版总结会议
    开会过程:主要是在两个地方,一个是基教在课堂上我们就进行了一些讨论,然后接着就是在寝室里面。讨论的问题:首先是我们为什么没有满足老师对我们的期望,对软件进行评估时,老师评价较低对我们的产品。第二为什么会造成这种情况,我们从自身到项目进行了多次思考。第三如果我们要完成老师......
  • 5.27每日总结
    今天对团队项目的App进行了收尾,基本完成了整个项目的开发,现在可以下载到用户的手机上进行使用,下面是一些成果展示。 ......
  • 总结我做的Promise题
    前言关于Promise的讲解文章实在太多了,在此我就不写讲解了,直接实战检测自己对Promise的理解,下面是我做过的众多Promise题里面挑出来的13道题,我觉得容易错或者值得考究知识点的题,如果你想考察自己对Promise的掌握程度,可以做做看。这些题是我从下面两个链接的题目又选出来的......
  • java后端开发流程总结
    流程简介:1、数据库见表(工具建表和cmd命令行(sql语言)两种方式)2、前端页面准备(html+css+js)3、controler层编写(针对具体功能编写,比如登录功能,在这一层获取前台输入的账号密码。这是就可以等待来自数据库里的数据了)4、接着编写serverdao层依据controler层的功能编写相应的get......
  • 软件工程课程总结
    转眼之间,一个学期又结束了,在本学期上了《软件工程》这门课,我学到了很多,下面进行课程总结:  开学的时候,写了开课博客,计划在这个学期,认真学习web项目开发和Android的开发,每天坚持学习。完成程度:学习了mybatis,springboot和vue框架,并在团队项目中使用了上述技术,并通过上网查询相......
  • 【基于容器的部署、扩展和管理】3.5 高可用性和故障恢复机制
    3.5高可用性和故障恢复机制云原生的高可用性是指在云原生环境中,通过自动化工具和技术手段,实现软件发布的高可用性机制。其主要思想是通过自动化部署、自动化监控、自动化修复等手段,提高软件系统的可用性和稳定性,从而减少系统故障和停机时间。故障恢复机制是指在云原生环境中,当系......