【算法专题】工欲善其事必先利其器—— C++ STL中vector(向量/不定长数组)的常用方法总结
#include<iostream>
#include<cstdio>
#include<string>
#include<vector>//不定长数组(向量)所需要包含的头文件 using namespace std; const int maxn = ; int n; int arr[]={,,,,};
/*不定长数组的声明方法*/ vector <int> pile;
//vector<T> v1 vector保存类型为T的对象。默认构造函数,v1为空
vector <int> pile_copy;
//vector<T> v2(v1) v2是v1的一个副本
vector <int> pile2(,);
//vector<T> v3(n,i) v3包含n个值为i的元素
vector <int> pile3();
//vector<T> v4(n) v4含有值初始化的元素的n个副本 如果为整形(int) 则为0 若为字符串(string)类型 则为空
vector <int> pile4{,};
//初始化第一个元素为1,第二个元素为2,其余按照默认值(0)初始化
vector <int> pile5(arr,&arr[]);
//以区间(beg;end)做为初值的vector
/*
此外不定长数组不限于基本类型 还可以是结构体类型(结构体要定义为全局的,否则会出错)
也可以是声明不定长类型的二维数组
*/
vector <vector <int> > pile6;//声明一个二维不定长数组 /* 不定长数组的使用方法*/ pile.push_back();
//尾部插入数字 1
pile.pop_back();
//在尾部删除一个元素
cout<<pile2[]<<endl;
//可以用数组方法访问不定长数组元素
pile3.assign(arr,&arr[]);
//吧arr[0]到arr[5]中的元素进行拷贝
vector<int>::iterator it;
//声明一个叫it的整形的迭代器
for(it=pile2.begin();it < pile2.end(); it++)
cout<<*it<<endl;
//利用迭代器对不定长数组进行遍历
//pile2.end();指向最后一个元素的下一个位置
/*关于迭代器:
迭代器(Iterator),提供了访问容器中对象的方法。
例如,可以使用一对迭代器指定list或vector中的一定范围的对象。
迭代器就如同一个指针。事实上,C++的指针也是一种迭代器。
但是,迭代器也可以是那些定义了operator*()以及其他类似于指针的操作符地方法的类对象;*/
pile2.insert(pile2.begin()+i,a);
//在第i+1个元素前面插入a;
pile2.eraser(pile2.begin()+);
//删除第3个元素
pile2.erase(pile2.begin()+i;pile2.begin()+j);
//删除i到j-1的区间(从0开始)
cout<<pile2.size()<<endl;
//获取当前不定长数组的大小
pile2.clear();
//清空向量
cout<<"pile大小是否为0:"<< (pile.empty()?"空":"不空")<<endl;
//判断pile是否为空
cout<<"pile可容纳的元素最大数量:"<<pile.max_size()<<endl;
//判断Pile可容纳的最大数量
pile.resize();
//将元素数量改成5,如果pile变大,则多的按默认走
pile.resize(,);
//将元素数量改成5,如果pile变大,则多的赋值成9
拓展阅读:
推荐博客地址: 对vector的用法及定义有较为详细的讲解 使用时可以留作参考
【算法专题】工欲善其事必先利其器—— C++ STL中vector(向量/不定长数组)的常用方法总结的更多相关文章
- STL之vector(不定长数组)
vector就是一个不定长数组,另外它把一些常用操作“封装”在了vector类型内部.例如,若a是一个vector,可以用a.size()读取它的大小,a.resize()改变大小,a.push_ba ...
- STL中vector、list、deque和map的区别
1 vector 向量 相当于一个数组 在内存中分配一块连续的内存空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capac ...
- 【转】STL中vector、list、deque和map的区别
1.vector 向量 相当于一个数组 在内存中分配一块连续的内容空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capacity()函数 ...
- C++的STL中vector内存分配方法的简单探索
STL中vector什么时候会自动分配内存,又是怎么分配的呢? 环境:Linux CentOS 5.2 1.代码 #include <vector> #include <stdio ...
- (STL初步)不定长数组:vector
STL是指C++的标准模板库.(存储着一些常用的算法和容器) vector是一个不定长数组.它把一些常用的操作”封装“在vector类型内部. 例如,a是一个vector.1对元素的操作有,可以用a. ...
- C++ STL中vector(向量容器)使用简单介绍
原文:http://www.seacha.com/article.php/knowledge/cbase/2013/0903/2205.html C++ vector(向量容器)是一个线性顺序结构.相 ...
- STL中vector的赋值,遍历,查找,删除,自定义排序——sort,push_back,find,erase
今天学习网络编程,那个程序中利用了STL中的sort,push_back,erase,自己没有接触过,今天学习一下,写了一个简单的学习程序.编译环境是VC6.0 这个程序使用了vect ...
- STL中 vector 和 list 一些特性
STL中的vector特点是: 其容量在需要时可以自动分配,本质上是数组形式的存储方式.即在索引可以在常数时间内完成.缺点是在插入或者删除一项时,需要线性时间.但是在尾部插入或者删除,是常数时间的. ...
- C++STL之Vector向量详解,用法和例子 一起学习 一起加油
C++ STL之vector用法总结 1 ...
随机推荐
- 在Ubuntu 12.04 - 64bit中安装CodeSourcery时提示错误
安装时提示错误,Your 64-bit Linux host is missing the 32-bit libraries requied to install and use Sourcery C ...
- IOS开发苹果官方Sample Code及下载地址
IOS开发苹果官方Sample Code及下载地址 在线浏览地址:https://developer.apple.com/library/ios/navigation/#section=Resourc ...
- 谈Linux
新手谈Linux 目录: 什么是Linux? Linux与UNIX的区别 Linux与Windows比较 什么是Linux发布版? Linux应用领域 Linux版本的选择 怎么学习Linux? ...
- js关闭当前页面不弹出提示的方法
js关闭当前页面不弹出提示的方法 js关闭当前页面不弹出提示的方法 "window.opener=null;window.open('','_self','');window.close() ...
- Android中怎么去除标题栏详解
怎么出去标题栏,我再另一个博客中亦有实例在这里再详细的解释一下,也让自己能更加巩固最简单也是小重要的东西. 这里有两种方法是比较好的... 第一种: 首先,在values中建一个theme.xml 代 ...
- PHP中判断输入验证码是否一致
首先用session将随机生成的验证码的值传到页面,然后获取当前文本框中输入的值 进行对比:代码如下: 生成的随机数,把它传到session里面 <? session_start(); 必 ...
- PLAN : 入门题目 ( update )
更新后 step 1 : A07, A11, A12,A14,A15,A18,A22,A24,A25,A26 A27,A29,A31,A32,A34,A59,A66,A69,A84,B24 B45,B ...
- wpf中xps文档合并功能实现
跟着上一篇的xps文档套打的文章,近期一直在研究xps打印技术,其中用户提到了一个需求,要求能够多页面进行打印,我的想法是,先生成xps文件,然后将文件读取出来以后,合并成一个文件来处理. 如果要是直 ...
- FormsAuthentication知多少
前述:对于FormsAuthentication相信大家都烂熟于胸了,这里只是做一下小结. 一.先看一下使用FormsAuthentication做登录认证的用法 用法一: FormsAuthenti ...
- [转]iOS Tutorial – Dumping the Application Memory Part 2
Source:https://blog.netspi.com/ios-tutorial-dumping-the-application-memory-part-2/ In my previous bl ...