vector简单使用
在刷ccf题的时候日常做完去网上查看别的同学怎么做的
发现有使用vector后三十几行代码就写出来的,虽然时间复杂度和我一样十几毫秒,but !我看中了它的代码量啊!多么的少啊!
所以百度了vector的使用方法,这里,只总结一些我暂时会用到的
1.简单的介绍vector:
在c++语言中使用,是一种顺序容器,事实上和数组差不多,但它比数组更优越。一般来说数组不能动态拓展,因此在程序运行的时候不是浪费内存,就是造成越界。而vector正好弥补了这个缺陷,它的特征是相当于可分配拓展的数组,它的随机访问快,在中间插入和删除慢,但在末端插入和删除快。/ps 官方用语
2.什么时候使用:
如果你想使用数组来进行插入删除查找时,其中会不可避免的遇到移动一大堆的数组元素,比如某个元素的值被删除,那么后面的都要向前移动的时候,推荐你使用vector,因为它不考虑数组下标啊!!!通过指针删除元素的值可以说非常方便了!节省了很大的时间啦,但是问题也是在这里出现:在中间插入与删除慢,emmm这个慢其实比大容量数组我们自己移动快很多好伐
3怎么使用:
头文件:
#include <vector>
基本操作:
//容量
vec.size();//向量大小
vec.max_size();//向量最大容量
vec.resize();//更改向量大小
vec.capacity();//向量真实大小
vec.empty();//向量判空
vec.shrink_to_fit(); //减少向量大小到满足元素所占存储空间的大小
//修改
vec.assign(); //多个元素赋值,类似于初始化时用数组进行赋值
vec.push_back();//末尾添加元素
vec.pop_back();//末尾删除元素
vec.insert();//任意位置插入元素
vec.erase();//任意位置删除元素
vec.swap();//交换两个向量的元素
vec.clear();//清空向量元素
//迭代器
vec.begin();//开始指针
vec.end(); //指向最后一个元素的下一个位置
vec.cbegin(); //指向常量的开始指针,意思就是不能通过这个指针来修改所指的内容,但还是可以通过其他方式修改的,而且指针也是可以移动的。
vec.cend();//指向常量的末尾指针:
//元素的访问
vec[]; //下标访问,并不会检查是否越界
vec.at(); //at方法访问,以上两者的区别就是at会检查是否越界,是则抛出out of range异常
vec.front();//访问第一个元素:
vec.back();//访问最后一个元素:
int* p = vec.data(); //返回一个指针,可行的原因在于vector在内存中就是一个连续存储的数组,所以可以返回一个指针指向这个数组。
4.使用案例
#include<cstdio>
#include<vector>
#include<iostream>
#include<algorithm> using namespace std; int main()
{
int num;
vector<int>v1; //定义vector
vector<int>::iterator it; //定义vector迭代器
cout<<"请输入5个整数:"<<endl;
for(int i = ;i <= ;i++)
{
cin>>num;
v1.push_back(num);
}
printf("\n");
for(it = v1.begin();it != v1.end();it++)
cout<<*it<<" ";
cout<<endl;
it = v1.begin();
it += ;
cout<<"第二个数为: "<<*it<<" "<<endl;
v1.erase(it); //删除倒数第二个数
it = v1.begin();
it += ;
cout<<"删除之前第二个数后,新的第二个数为:"<<*it<<" "<<endl;
v1.clear();
cout<<"清空后元素个数为:"<<v1.size()<<endl; return ;
}
可以看见,我们删除一个元素后,该位置自动由后面的元素填充,不需要我们手工移啊移,而且也不需要实现定义数组的大小,避免溢出,很方便啦
vector简单使用的更多相关文章
- C++线性序列容器<vector>简单总结
		C++线性序列容器<vector>简单总结 vector是一个长度可变的数组,使用的时候无须声明上限,随着元素的增加,Vector的长度会自动增加:Vector类提供额外的方法来增加.删除 ... 
- c++  头文件 及 sort 和 vector简单介绍
		c++ sort :http://www.16kan.com/post/997260.html http://wenku.baidu.com/view/e064166daf1ffc4ffe47ac6 ... 
- c++ vector 简单实现。
		第二次修改: 1)熟悉基本的模板编程,头文件和定义必须放到一起. 2)熟悉内存管理模板类 allocator<T>. 1.使用标准库的内存管理类 allocator<T> 代替 ... 
- C++STL vector简单使用练习1
		#include <iostream> #include <vector> #include <numeric> using namespace std; int ... 
- Vector简单介绍
		/*枚举就是Vector特有的取出方式发现枚举和迭代器很像其实枚举和迭代是一样的因为枚举的名称以及方法的名称都过长了.所以被迭代器取代了枚举郁郁而终了. */ import java.util.*;c ... 
- STL vector简单用法
		初涉c++,此为<算法笔记>中的内容,有待个人理解完善. vector vector翻译为向量,叫做"变长数组"更容易理解. 头文件:#include<vecto ... 
- STL - 容器 - vector简单应用
		VectorTest.cpp #include <vector> #include <iostream> #include <string> #include &l ... 
- c++vector简单实现
		const int DEFAULT_CAP = 3; template <typename T> class vector { // int capacity; T* _data; int ... 
- vector简单常用用法
		Vector是什么? vector翻译为向量,从某种角度来说就是一个可以变长的数组,它会根据需要自动扩充数组的容量,除此之外其是一个STL中的模板类,其 还具有一些内部的方法. Vector的使用方法 ... 
随机推荐
- [LuoguP2167][SDOI2009]Bill的挑战_容斥原理/状压dp
			Bill的挑战 题目链接:https://www.luogu.org/problem/P2167 数据范围:略. 题解: 因为$k$特别小,想到状压. 状压的方式也非常简单,就是暴力枚举. 但是会不会 ... 
- [LuoguP2124]奶牛美容_bfs_floyd_曼哈顿距离
			奶牛美容 题目链接:https://www.luogu.org/problem/P2124 数据范围:略. 题解: 发现数据范围只有$50$,显然可以直接$bfs$求出联通块,$floyd$求出相邻两 ... 
- 注解@PostConstruct与@PreDestroy详解及实例
			Java EE5 引入了@PostConstruct和@PreDestroy这两个作用于Servlet生命周期的注解,实现Bean初始化之前和销毁之前的自定义操作.此文主要说明@PostConstru ... 
- Photon Server初识(五) --- 客户端连接服务端
			准备:Unity开开发IDE. 一.新建Unity3D项目 导入包,在资源下新建目录 Plugins .在之前解压的SDK目录 lib中找到 Photon3Unity3D.dll,拖到新建的目前下 二 ... 
- Java手写简单HashMap一(包括增加,查找,toString,泛型)
			@Java 300 学习总结 HashMap底层采用实现采用了哈希表,结合了"数组和链表". 原理如图 一.定义HashMap类. 首先需要定义一个节点来存储数据,构成链表结构. ... 
- S02_CH10_ User GPIO实验
			S02_CH10_ User GPIO实验 在之前的第四章课程中,我们详细的讲解了如何在VIVADO软件下封装一个简单的流水灯程序.在ZYNQ开发过程中,有时候我们可能会需要与ARM硬核进行通信,在这 ... 
- DVWA漏洞演练平台 - 文件上传
			DVWA(Damn Vulnerable Web Application)是一个用来进行安全脆弱性鉴定的PHP/MySQL Web应用,旨在为安全专业人员测试自己的专业技能和工具提供合法的环境,帮助w ... 
- 服务返回的json数据过大,nginx无法返回给client
			现象:请求同样的服务器,N多个接口中,只有一个接口未返回:从日志看,请求已到后端服务,并返回 解决方案:配置nginx缓冲大小 ###Nginx的缓冲区的大小 proxy_buffer_size 5m ... 
- net core体系-Xamarin-2概要(lignshi)
			通过本套课程的学习,各位学员能够对Xamarin有一个比较清楚的认识,掌握Xamarin常用功能的使用方法,能够比较熟练的使用Xamarin进行App(移动应用)的开发,能够比较轻松.快速地投入项目当 ... 
- fastclick插件学习(一)之用法
			原理 在检测到touchend事件后, 会通过dom自定义事件模拟一个click事件,并把浏览器300ms之后真正触发的点击事件屏蔽掉,fastclick是不会对PC浏览器添加监听事件 使用 1.引入 ... 
