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

相关推荐
多米Domi01119 小时前
0x3f第九天复习(考研日)(10.57-14:00)
python·算法
我不是8神19 小时前
序列化与反序列化详解
c++
byzh_rc19 小时前
[模式识别-从入门到入土] 拓展-EM算法
算法·机器学习·概率论
MSTcheng.19 小时前
【C++STL】map / multimap 保姆级教程:从底层原理到实战应用!
开发语言·c++·stl·map·红黑树
努力学算法的蒟蒻19 小时前
day41(12.22)——leetcode面试经典150
算法·leetcode·面试
liliangcsdn19 小时前
Python拒绝采样算法优化与微调模拟
人工智能·算法·机器学习
Christo319 小时前
2024《A Rapid Review of Clustering Algorithms》
人工智能·算法·机器学习·数据挖掘
AndrewHZ19 小时前
【图像处理基石】图像梯度:核心算法原理与经典应用场景全解析
图像处理·算法·计算机视觉·cv·算子·边缘提取·图像梯度
让学习成为一种生活方式19 小时前
组蛋白短链酰化修饰--文献精读187
算法
ULTRA??19 小时前
基于range的函数式编程C++,python比较
c++·python·kotlin·c++20