蓝桥杯C++常用STL

小记:

队列、stack都是push

只vector是push_back

set是insert

1. vector(动态数组)

cpp 复制代码
vector<int> v;
v.push_back(1);      // 尾部插入元素(O(1) 均摊)
v.pop_back();        // 删除尾部元素(O(1))

int n;cin >> n;
vector<int> nums;
nums.reserve(n); //预分配n长度空间
vector<int> v1(n,0);//另一种预分配

v.insert(v.begin()+2, 5); // 在指定位置插入(O(n))
v.erase(v.begin()+1);     // 删除指定位置元素(O(n))

v.size();            // 当前元素数量

v.find(v.begin(),v.end(),target);//找到元素对应下标
auto it = std::find(vec.begin(), vec.end(), target);
if (it != vec.end()) {
    std::cout << "找到元素,位置索引: " << std::distance(vec.begin(), it);

v.clear();           // 清空元素(不释放内存)
cpp 复制代码
vector<int> v[N];
//N个一维的vector

2. priority_queue(优先队列,堆)入队则排序

cpp 复制代码
//最小堆,最小元素出列
priority_queue<int,vector<int>,greater<int>>pq;
//默认最大堆,最大元素出列
priority_queue<int>q;//
//左大greater  sort(,greater<int>());

pq.size()>1
ll x=pq.top();pq.pop();//取出第一个队头最小元素,并弹出
ll y=pq.top();pq.pop();//取出当前第一个队头最小元素,并弹出
ans+=x+y;//求和,合并
pq.push(x+y);//合并的部落再入队列,排列后再重复上述操作


priority_queue<int> pq;
pq.push(30);          // 插入元素(O(log n))
pq.pop();             // 删除堆顶元素(O(log n))
pq.top();             // 访问最大元素(O(1))

3. map(键值对映射)

升序,空间小,时间O(logn)

cpp 复制代码
map<string, int> m;
m["apple"] = 5;       // 插入/修改键值对(O(log n))
m.insert({"banana", 3}); //直接插入键值对,一对
auto it = m.find("apple"); // 查找键(O(log n))
m.erase("banana");    // 删除键
m.emplace("cherry", 7); // 直接构造键值对

map遍历:

cpp 复制代码
for(auto val:Map)//遍历map 根据题意出现次数超过一半,值*2>n*m
{
	int current_val = val.second;//每次取出键中的值
	if(current_val*2>n*m)//值出现超过一半
	{
		ans=val.first;//取出其中的键
		break;//跳出
	}
		
}
unordered_map

平均O(1)最坏On 适用于无序、高频查寻 空间占用大

cpp 复制代码
unordered_map<int, int> h;
for (int i = 0; i < n; i ++) {
        cin >> a[i];
        h[a[i]] = i;
    }
h.count(x - b[i])//找键是否存在 x-b[i]是否==a[i]

4.set (集合) 去重+排序

cpp 复制代码
set<pair<int, int>> positions;
positions.insert(simulatePath(steps, i, 'F'));
positions.size();

set<int> s;
s.insert(5);          // 插入元素(O(log n))
s.erase(5);           // 删除元素(O(log n))
s.find(5);            // 查找元素,返回迭代器(O(log n))
s.count(5);           // 存在性检查(0或1)
s.lower_bound(3);     // 第一个 >=3 的元素
s.upper_bound(8);     // 第一个 >8 的元素

sort pair<int,int>默认排序规则

  1. 比较 .first
    先比较两个 pair 的第一个元素 a.firstb.first
    • 如果 a.first < b.first,则 a 排在 b 前面。
    • 如果 a.first > b.first,则 a 排在 b 后面。
  1. .first****相等,再比较 .second
    a.first == b.first,则比较 a.secondb.second
    • 如果 a.second < b.second,则 a 排在 b 前面。
    • 如果 a.second > b.second,则 a 排在 b 后面。

5.pair (二元组)

cpp 复制代码
vector<pair<int, int>> directions = {{0, -1}, {1, 0}, {0, 1}, {-1, 0}};
int direction = 0;//
int dr = directions[direction].first;//第一组的第一个元素
int dc = directions[direction].second;//第一组的第二个元素

6.stack(后进先出)

cpp 复制代码
stack<int> s;
s.push(10);           // 压栈(O(1))
s.pop();              // 弹栈(O(1)),不返回元素
s.top();              // 查看栈顶元素(O(1))

queue

相关推荐
wubba lubba dub dub75037 分钟前
第二十七周 学习周报
学习·算法·机器学习
小白程序员成长日记40 分钟前
力扣每日一题 2025.11.30
数据结构·算法·leetcode
崎岖Qiu41 分钟前
二叉树的非递归后序遍历-双栈法
算法·二叉树·力扣·深度优先遍历·
Demon--hx41 分钟前
[C++]迭代器失效问题
前端·c++
liulilittle41 分钟前
C++ 计算当前时区偏移量秒数(GMT/UNIX偏移量)
linux·c++·unix
再睡一夏就好43 分钟前
深入理解Linux程序加载:从ELF文件到进程地址空间的完整旅程
linux·运维·服务器·c++·学习·elf
lijiatu1008644 分钟前
[C++] 上锁、解锁、获取锁、释放锁的区别
开发语言·c++
竹杖芒鞋轻胜马,夏天喜欢吃西瓜1 小时前
哈希算法解析
算法·哈希算法
阿沁QWQ1 小时前
STL和string实现
开发语言·c++