蓝桥杯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

相关推荐
先吃饱再说9 小时前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天9 小时前
C++ 基础入门完全指南
c++
黄敬峰11 小时前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术13 小时前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六16 小时前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术17 小时前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize17 小时前
初识DFS 与 BFS:递归、队列与图遍历
算法
罗西的思考1 天前
机器人 / 强化学习】HIL-SERL:人类在环驱动的具身智能进化框架
人工智能·算法·机器学习
美团技术团队1 天前
LongCat 开源 VitaBench 2.0:长期动态智能体基准新标杆
人工智能·算法