STL的基本知识

STL 基础知识

(1)若果要在函数传递参数的时候忽略函数类型,那么就要使用模版函数:

函数模版忽略函数类型:在需要忽略函数类型的函数前面加上

Template<class T(模版名称)>
int add(T a,T b){
    return a+b;
}

加上模版后,传递的参数就可以是任意类型啦,是不是很方便呀。

函数模版可以自动推导类型:
若要显示类型:
则可以用 Myswap<int>(T a,T,b)
可以严格的进行类型推导,所以在函数模版中 int 和char 不能进行转换</int>

(2)
c语言的编译过程:
c语言的实现过程

set和mlutiset

插入删除元素:

insert(m)
erase(pos) //删除pos迭代器所指的元素,返回下一个容器的迭代器
erase(beg,end) //删除迭代器[beg,end]区间所指的元素,返回下一个容器的迭代器
erase(m)  //删除元素m

查找集合元素

find(m)    //查找m是否存在,若存在返回该元素的迭代器,若不存在,返回map.end();
lower_bound(m)  //返回第一个大于等于m元素的迭代器
upper_bound(m)  //返回第一个大于m 元素的迭代器i;;
equal_range(m)   //返回lower_bound()和upper_bound()的返回值
//返回值为pair类型

pair(set<int>iterator,set<int> iterator) pr=equal_range();
用.first和.second访问

对组

创建对组

1.pair<string,int> pair1=("name1",20);
2.pair<string,int> pair2=make_pair("aaa",200);

vector

动态数组的增长原理:当内存不够时,重新申请两倍的空间
常用API:

一.vector的构造及其初始化:
构造:
vector<class> T(数组名)
初始化:
1.
int arr[10]={,,,,};
vector<int >t(arr,arr+sizeof(arr)/sizeof(int));
2.
vector<int >v3(t.begin(),t.end());
3.
vector<int> v4(v3);
4.
vector<int> v4;
v4.assign(v3.begin(),v3.end());
5.
vector<int> v4;
v4=v3;
6.vector<int> v4;
v4.swap(v3);
二.vector大小操作
vector<int> v;
v.size()    // 返回元素数量
v.empty()   //判断元素是否为空
v.resize(n,m)    //重新定义vector的容量,小于元素数量后面的元素会被抛弃,大于元素个数会自动在后面添加m
v.capacity();   //返回动态数组的容量
三,vector数据存取操作:
void test04(){
    vector<int> v1(a,a+4);

    for(int i=0;i<4;i++){
        cout<<v1.at(i)<<" ";
        //cout<<v1[i]<<" ";
    }
    cout<<"\n";
    cout<<v1.front()<<"\n";   //返回的是元素,而不是迭代器
    cout<<v1.back()<<"\n";
}
四.vector的插入和删除操作:
void test05(){
    vector<int> v1(a,a+4);
    v1.insert(v1.begin(),30);
    v1.push_back(40);
    v1.push_back(50);
    v1.insert(v1.begin()+2, 100);
    Print(v1);
    v1.pop_back();
    v1.pop_back();
    Print(v1);
    v1.erase(v1.begin()+1,v1.end());
    Print(v1);
    cout<<v1.size()<<"\n";
    v1.clear();
    cout<<v1.size()<<"\n";
}
//输出结果:
//30 1 100 2 3 4 40 50 
//30 1 100 2 3 4 
//30
//1
//0
全部评论

相关推荐

05-29 19:11
已编辑
北方民族大学 Java
😭😭😭😭本人26届双非本,后端选手。从25年秋招开始,一直到春招5月份,一共面了12次字节。可以说后面能继续投递面上字节大概率是因为前面一直累计的面评还不错,但是最终的结果往往不尽如人意,黄梁一梦。timeline:如标题,总共面了12次字节,4个不同的岗位。第一次:抖音生活服务测开二面完排序挂第二次:TikTok国际化电商测开三面完排序挂第三次:飞书后端安全团队三面完挂第四次:飞书后端偏基架团队三面完过,HR面完之后询问综合排序不推进。我知道像BAT这样的公司,双非本想拿到一张入场券有多难,也知道每次挂在排序/三面/HR面,那种差一步上岸又被打回原点的落差感有多磨人。可是最后一次字节的这个岗位,已经是5月中旬才开始面得了,春招末期的岗位,我本以为真的缺人,三面过的那天,我真的以为就差一步hr面就稳了,但是,最终的结果很遗憾,综合排序综合排序,不推进了。如果是技术能力的问题,我想也不会每一轮技术面给我通过。思来想去。难道真的就是因为我们双非有案底,所以最后的一切又算什么呢。付出这么多的时间精力,还是抵不过双非学历太差吗?既然如此一开始直接卡掉简历不用给面试不就行了嘛,每一轮面试都给我们生的希望,最后的最后又回到了那个必输的起点。12次字节,说不遗憾是假的,也无数次怀疑过自己:是不是我算法刷得还不够?是不是项目亮点讲得不够好?是不是学历就是一道跨不过去的坎?但回头看,这一年的秋招到春招,从面对面试官紧张到说话卡壳,到后来的从容面对,再到如今甚至能和面试官探讨AI&amp;大模型技术的一些方案思路,我已经比去年的自己强太多了。可能字节于我,真的是一场盛大的单恋,拼尽全力奔赴,却还是没能收到想要的回应。前路漫漫,字节的梦碎了,但我的路还在继续,希望下一站,会有属于我的一场徐风。
不愿吃饼的山羊很友好:你的心理素质是真的强大,如果是我碰到这样都会疯了
点赞 评论 收藏
分享
04-15 09:59
门头沟学院 C++
yy_11:小公司人家没必要泄密,大公司都是本地部署了
你想吐槽公司的哪些规定
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务