vector.reserve and resize &&vector与map结合
2016-03-14 15:02
363 查看
vector初始化 vector V(8,10); //初始化数组v含有8个元素,每个元素的值为10
vector里面的 memset fill(C.begin(),C.end(),0);}
vector 的reserve增加了vector的capacity,但是它的size没有改变!而resize改变了vector的capacity同时也增加了它的size!
原因如下:
reserve是容器预留空间,但在空间内不真正创建元素对象,所以在没有添加新的对象之前,不能引用容器内的元素。加入新的元素时,要调用push_back()/insert()函数。
vector里面的 memset fill(C.begin(),C.end(),0);}
vector 的reserve增加了vector的capacity,但是它的size没有改变!而resize改变了vector的capacity同时也增加了它的size!
原因如下:
reserve是容器预留空间,但在空间内不真正创建元素对象,所以在没有添加新的对象之前,不能引用容器内的元素。加入新的元素时,要调用push_back()/insert()函数。
resize是改变容器的大小,且在创建对象,因此,调用这个函数之后,就可以引用容器内的对象了,因此当加入新的元素时,用operator[]操作符,或者用迭代器来引用元素对象。此时再调用push_back()函数,是加在这个新的空间后面的。 两个函数的参数形式也有区别的,reserve函数之后一个参数,即需要预留的容器的空间;resize函数可以有两个参数,第一个参数是容器新的大小,第二个参数是要加入容器中的新元素,如果这个参数被省略,那么就调用元素对象的默认构造函数。下面是这两个函数使用例子:
例子1: vector<int> myVec; myVec.reserve( 100 ); // 新元素还没有构造, // 此时不能用[]访问元素 for (int i = 0; i < 100; i++ ) { myVec.push_back( i ); //新元素这时才构造 } myVec.resize( 102 ); // 用元素的默认构造函数构造了两个新的元素 myVec[100] = 1; //直接操作新元素 myVec[101] = 2; 例子2: #include <vector> #include <iostream> using namespace std; int main(int argc, char* argv[]) { vector<int> vect; vect.push_back(1); vect.push_back(2); vect.push_back(3); vect.push_back(4); vect.reserve(100); cout<<vect.size()<<endl; //size为4,但是capacity为100 int i = 0; for (i = 0; i < 104; i++) { cout<<vect[i]<<endl; } return 0; } 例子3: #include <vector> #include <iostream> using namespace std; int main(int argc, char* argv[]) { vector<int> vect; vect.push_back(1); vect.push_back(2); vect.push_back(3); vect.push_back(4); vect.resize(100); //新的空间不覆盖原有四个元素占有的空间,现在size和capacity都是100 cout<<vect.size()<<endl; int i = 0; for (i = 0; i < 104; i++) { cout<<vect[i]<<endl; } return 0; } 例子4: #include <vector> #include <iostream> using namespace std; int main(int argc, char* argv[]) { vector<int> vect; vect.resize(100); //分配100个空间 vect.push_back(1); vect.push_back(2); vect.push_back(3); vect.push_back(4); cout<<vect.size()<<endl; //现在size和capacity都是104 int i = 0; for (i = 0; i < 104; i++) { cout<<vect[i]<<endl; } return 0; } 当你想开三维数组的时候,用这个就可以了 #include<cstdio> #include<cstring> #include<vector> #include<map> #include<iostream> using namespace std; map<int,vector<int> >p; int main() { int n,m; while(scanf("%d%d",&n,&m)!=EOF) { p.clear(); int tmp; for(int i=0;i<n;i++) { scanf("%d",&tmp); if(!p.count(tmp)) p[tmp]=vector<int>(); p[tmp].push_back(i+1); } for(int i=0;i<m;i++) { int k,v; scanf("%d%d",&k,&v); printf("%d\n",p[v][k-1]); //居然才知道,原来map里面可以直接这样定位一个数 } } } /* 10 5 1 2 3 2 5 6 3 8 5 8 */
相关文章推荐
- java中HashMap详解
- 干货:在嵌入式系统设计中,五个让传感器变得更简单的技巧!
- Apple Pay接入详细教程
- Nim Game---292
- 【bzoj3203】[Sdoi2013]保护出题人 凸包+三分法
- UITextField加密输入属性
- css:position 与 z-index 问题(1)
- js判断当前环境是否为苹果手机
- viewpager+fragment
- weibo爬虫计划,以及普适爬虫框架的搭建
- NYOJ-背包问题
- Android之崩溃日志本地存储与远程保存
- java 中类加载过程
- java微信开发-token验证
- 基于redis的处理session的方法
- 从jQuery中学习来的另一种继承方式(技巧)
- for应用,转义字符,break和continue的区别
- NN学习笔记
- Linux基础回顾之基础命令四
- 视图控制器转场详解