STL-vector(ACM)
1.长度可变的数组
2.这里不是很懂,v.size() 代码源里说这个v.size()是无符号类型的,使用时要说明类型,
但是我在使用时并没有出现warning,有大佬知道原因吗?
3.vector是有v.clear()的
4.vector按字典序比较
重构函数(默认)
vector<int> v;
vector<int> v(3, 100); // 大小为3,每个数都是100
//下方为{}操作 C++11 可以用的
vector<int> v{1, 2, 3, 4}; // 把1,2,3,4塞进v里面,大小为4,元素1-4
基础操作
v.size(); // unsigned类型
v.resize(); v.empty();
v.clear(); // 只能清空表面 // 只有这两个操作
v.push_back();
v.pop_back(); // 下面两个是地址
v.begin(); // 指第一个元素的位置
v.end();// 指最后一个元素的地址+1的地址
// 例如
// 1 2 3 4 5 6 7 8
// ^ ^
// | |
// v.begin() v.end() v.insert(地址,元素) // 地址前一个插入元素
// 下方操作会在3423后面和53之间插入7
vector<int> v{1, 2, 3423, 53, 542};
v.insert(v.begin() + 3, 7);
// 括号里第一个是地址,第二个是要插入的元素
// 操作时间是O(n)的 v.erase(地址,元素); // 删去对应的元素 sort(v.begin(), v.end()); // 排序 lower_bound(v.begin(), v.end(), 100); auto it = lower_bound(v.begin(), v.end(), 100);
// 返回前闭后开地址区间内 >= 100 的第一个元素的迭代器
// 这个查找必须在有序列里面,查询方式是二分,时间复杂度O(logn) upper_bound(v.begin(), v.end(), 100)
auto it = upper_bound(v.begin(), v.end(), 100);
// 返回前闭后开地址区间内 > 100 的第一个元素的迭代器
// 这个查找必须在有序列里面,查询方式是二分,时间复杂度O(logn)
迭代器
// 迭代器(可以暂时理解为STL的指针)
vector<int>::iterator it = v.begin(); // 初始化 // 迭代器遍历模板(auto C++11后可用,自动判断后面的类型)
for (auto it = v.begin(); it != v.end(); it ++) {
cout << *it << endl;
}
遍历新语法(C++11之后可以使用)
for (int x : v) {
cout << x << endl;
}
// 遍历每一个元素,每一次x作为每个元素,int 可改为 auto等
// 普通数组、STL数组、vector 都可使用
// 不会改变原来的值
for (int x : v) {
x += 1;
} // 改变的只是每次x的值,v中的每个元素都不会改变
// 像下边这样
for (int i = 0; i < v.size(); i ++) {
int x = v[i];
x += 1;
cout << v[i] << endl;
}
但是加上 & 就能 改
for (int &x : v) {
x += 1;
}
// 加了是下边的效果
for (int i = 0; i < v.size(); i ++) {
int &x = v[i];
x += 1;
cout << v[i] << endl;
}
存图(以后回来看)
for (int i = 1; i <= m; i ++) {
int u, v;
scanf("%d%d", &u, &v);
g[u].push_back(v);
g[v].push_back(u);
}
for (auto v : g[u]) {
}
STL-vector(ACM)的更多相关文章
- stl 在 acm中的应用总结
总结一些在acm中常用的小技巧,小函数 之前尝试着总结过很多次.都失败了,因为总是担心不全,理解的也不是很透彻.这次再来一次...其实之前保存了很多的草稿就不发布了,当然,下面说的很不全面,路过的大牛 ...
- hdu5438 Ponds[DFS,STL vector二维数组]
目录 题目地址 题干 代码和解释 参考 题目地址 hdu5438 题干 代码和解释 解答本题时参考了一篇代码较短的博客,比较有意思,使用了STL vector二维数组. 可以结合下面的示例代码理解: ...
- C++ STL vector容器学习
STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...
- STL vector
STL vector vector是线性容器,它的元素严格的按照线性序列排序,和动态数组很相似,和数组一样,它的元素存储在一块连续的存储空间中,这也意味着我们不仅可以使用迭代器(iterator)访问 ...
- STL vector用法介绍
STL vector用法介绍 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和f ...
- STL vector+sort排序和multiset/multimap排序比较
由 www.169it.com 搜集整理 在C++的STL库中,要实现排序可以通过将所有元素保存到vector中,然后通过sort算法来排序,也可以通过multimap实现在插入元素的时候进行排序.在 ...
- STL vector 用法介绍
介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
- STL vector使用方法介绍
介绍 这篇文章的目的是为了介绍std::vector,怎样恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
- stl——vector详解
stl——vector详解 stl——vector是应用最广泛的一种容器,类似于array,都将数据存储于连续空间中,支持随机访问.相对于array,vector对空间应用十分方便.高效,迭代器使ve ...
- C++STL vector详解(杂谈)
介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...
随机推荐
- 集合-ArrayList 源码分析
1.概述 ArrayList 是一种变长的集合类,基于定长数组实现.ArrayList 允许空值和重复元素,当往 ArrayList 中添加的元素数量大于其底层数组容量时,其会通过扩容机制重新生成一个 ...
- 6步带你用Spring Boot开发出商城高并发秒杀系统
摘要:本博客将介绍如何使用 Spring Boot 实现一个简单的商城秒杀系统,并通过使用 Redis 和 MySQL 来增强其性能和可靠性. 本文分享自华为云社区<Spring Boot实现商 ...
- 异步注解@Async使用及其部分调优
对于spring异步注解@Async的使用: 对于异步方法调用,从Spring3开始提供了@Async注解,该注解可以被标注在方法上,以便异步地调用该方法.调用者将在调用时立即返回,方法的实际执行将提 ...
- post-css/less/sass样式嵌套与命令之"&"符号—BEM
看了< less 的 & 详解 https://www.jianshu.com/p/127b0974cfc3>,对于此文再做一别补充 常见用法: 直接嵌套写法 .a{ colo ...
- day93:flask:Cookie&Session&请求钩子&捕获错误&上下文&Flask-Script
目录 1.HTTP的会话控制 2.Cookie 3.Session 4.请求钩子 5.捕获错误 6.上下文:context 7.Flask-Script 1.HTTP的会话控制 1.什么是会话控制? ...
- Java中ThreadLocal的用法和原理
用法 隔离各个线程间的数据 避免线程内每个方法都进行传参,线程内的所有方法都可以直接获取到ThreadLocal中管理的对象. package com.example.test1.service; i ...
- ORA-19870: error while restoring backup piece 数据库恢复报错
问题描述:用备份进行DG恢复,恢复过程中报错ORA-19870: error while restoring backup piece /backup/db_BJCCORA_20180724_02t8 ...
- ubuntu容器的远程xface桌面环境搭建
一.container: ubuntu20.04 二.commands: apt install xfce4 tigervnc-standalone-server # xface使用gdm3启动器 ...
- 香,一套逻辑轻松且智能解决PyQt中控件数值验证的问题
在PyQt开发中,时常需要对控件的值进行校验,如需要校验QCheckBox是否被选中,QLabel是否校验值是否为空等等.在复杂的业务场景下,这类控件如果数量很多,逐个校验就显得麻烦,需要一一获得控件 ...
- Java工作环境的配置与Eclipse的安装
如果您觉得这篇文章有用,请点个赞呀! Eclipse是一个开放源代码的.基于Java的可扩展开发平台.就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境.Eclipse 附带了一个标 ...