C++ STL

本文深入探讨C++ STL(标准模板库),介绍基础使用,包括Vector、Set、仿函数等容器,以及底层原理,如vector的增长策略和map的实现。通过实际题目,如评委打分、员工分组,展示STL在解决编程问题中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C++ 对模板(Template)支持得很好,STL 就是借助模板把常用的数据结构及其算法都实现了一遍,并且做到了数据结构和算法的分离。例如,vector 的底层为顺序表(数组),list 的底层为双向链表,deque 的底层为循环队列,set 的底层为红黑树,hash_set 的底层为哈希表。

基础使用

Vector

旧空间不足而重新配置一块更大空间,然后复制元素,再释放旧空间

#include <iostream>
#include <vector>
using namespace std;

int main(){
    vector<int> v;
    for (int i = 0; i < 5; i++)
    {
        v.push_back(i);
    }
    //vector的迭代器不支持it<v.end()的写法,因此循环条件只能it!=v.end()
    for (vector<int>::iterator it=v.begin(); it!=v.end();it++)
    {
        cout<<*it<<" ";
    }
    return 0;
}
void std::vector<int>::push_back(const int &__x);
void std::vector<int>::pop_back();
std::size_t std::vector<int>::size();
void std::vector<int>::clear();
insert(__position,__x);
erase(__position);
erase(__positionBegin,__positionEnd);
void PrintVector(vector<int>& v)
{
	for (auto x : v)
	{
		cout << x << " ";
	}
	cout << endl;
}    
    vector<int> v1;	//1.默认构造,无参构造

	for (int i = 0; i < 10; ++i)
	{
		v1.push_back(i);
	}
	PrintVector(v1);

	//2.利用区间方式构造
	vector<int> v2(v1.begin(), v1.end());
	PrintVector(v2);

	//3.n个element方式构造
	vector<int> v3(10, 100);	//10个100
	PrintVector(v3);

	//4.拷贝构造
	vector<int> v4(v3);	
	PrintVector(v4);

	//直接赋值
	vector<int> v2;
	v2 = v1;

	//assign赋值
	vector<int> v3;
	v3.assign(v1.begin(), v1.end());

	//n个element赋值
	vector<int> v4;
	v4.assign(10, 100);

Set

#include <iostream>
#include <set>
using namespace std;

//除了vector和string之外的STL容器都不支持*(it+i)的访问方式,因此只能按照如下方式枚举
int main()
{
    set<int> st;
    st.insert(5);
    st.insert(2);
    st.insert(6);
    for (set<int>::iterator it = st.begin(); it != st.end(); it++)
    {
        cout << *it << endl;
    }
    return 0;
}
#include <set>
#include <iostream>

int main(void)
{
    set<char> st;
    st.insert('C');
    set<int>::iterator it = st.find('C'); //在set中查找2,返回其迭代器
    cout << *it << endl;
    st.erase(st.find('C'));
    set<char>::iterator it = st.find('A');
    st.erase(it, st.end()); // erase elems after A
    cout << st.size() << endl;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值