#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(向量/不定长数组)的常用方法总结的更多相关文章

  1. STL之vector(不定长数组)

    vector就是一个不定长数组,另外它把一些常用操作“封装”在了vector类型内部.例如,若a是一个vector,可以用a.size()读取它的大小,a.resize()改变大小,a.push_ba ...

  2. STL中vector、list、deque和map的区别

    1 vector     向量 相当于一个数组    在内存中分配一块连续的内存空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capac ...

  3. 【转】STL中vector、list、deque和map的区别

    1.vector 向量 相当于一个数组 在内存中分配一块连续的内容空间进行存储.支持不指定vector大小的存储.STL内部实现时,首先分配一个非常大的内存空间预备进行存储,即capacity()函数 ...

  4. C++的STL中vector内存分配方法的简单探索

    STL中vector什么时候会自动分配内存,又是怎么分配的呢? 环境:Linux  CentOS 5.2 1.代码 #include <vector> #include <stdio ...

  5. (STL初步)不定长数组:vector

    STL是指C++的标准模板库.(存储着一些常用的算法和容器) vector是一个不定长数组.它把一些常用的操作”封装“在vector类型内部. 例如,a是一个vector.1对元素的操作有,可以用a. ...

  6. C++ STL中vector(向量容器)使用简单介绍

    原文:http://www.seacha.com/article.php/knowledge/cbase/2013/0903/2205.html C++ vector(向量容器)是一个线性顺序结构.相 ...

  7. STL中vector的赋值,遍历,查找,删除,自定义排序——sort,push_back,find,erase

    今天学习网络编程,那个程序中利用了STL中的sort,push_back,erase,自己没有接触过,今天学习一下,写了一个简单的学习程序.编译环境是VC6.0         这个程序使用了vect ...

  8. STL中 vector 和 list 一些特性

    STL中的vector特点是: 其容量在需要时可以自动分配,本质上是数组形式的存储方式.即在索引可以在常数时间内完成.缺点是在插入或者删除一项时,需要线性时间.但是在尾部插入或者删除,是常数时间的. ...

  9. C++STL之Vector向量详解,用法和例子 一起学习 一起加油

                                                                                    C++ STL之vector用法总结 1 ...

随机推荐

  1. How To : Create SQL Server Management Studio Addin

    原文 How To : Create SQL Server Management Studio Addin Read the full and original article from Jon Sa ...

  2. C#泛型回顾点滴

    前言 C#的泛型一直是学习者津津乐道的课题了,这确实是一个非常有用的特性,不过在实际使用中,还是有很多需要注意的地方,我们需要通过自己动手实践以及结合理论进行理解,最终总结出自己的编码规范和最佳实践 ...

  3. Winform无边框窗体(FormBorderStyle属性设为None)自定义移动

    为了界面的好看,有时候需要将窗体FormBorderStyle属性设为None,这样就可以根据自己的喜欢来设计界面.但这样窗体无法进行移动的.而且默认的窗体(FormBorderStyle=Sizab ...

  4. Talend open studio数据导入、导出、同步Mysql、oracle、sqlserver简单案例

    推荐大家一个BI工具:talend open studio.我也是刚接触,懂得不多,感觉比较神奇就想大家推荐一下... 由于公司项目,接触了一下BI工具talend,感觉功能很强大, 可以同步多种数据 ...

  5. 路由模块router实现step1

    hashchange事件 参考:http://www.cnblogs.com/rubylouvre/archive/2012/10/24/2730599.html 需要解决的问题: 1.IE6/7及兼 ...

  6. Orchard Logging

    Orchard 刨析:Logging 最近事情比较多,有预研的,有目前正在研发的,都是很需要时间的工作,所以导致这周只写了两篇Orchard系列的文章,这边不能保证后期会很频繁的更新该系列,但我会写完 ...

  7. 大规模web服务开发技术

    大规模web服务开发技术 总评        这本书是日本一个叫hatena的大型网站的CTO写的,通过hatena网站从小到大的演进来反应一个web系统从小到大过程中的各种系统和技术架构变迁,比较接 ...

  8. linux $ 类型变量 及Makefile 中 $ 类型变量的含义

    Shell 命令中: $$: shell pid $!: pid of the last process running in shell $?: shell command return code ...

  9. STL非变易算法 - STL算法

    欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/1394600460.html 原创:ST ...

  10. REST风格的服务

    使用ASP.NET Web Api构建基于REST风格的服务实战系列教程[三]——Web Api入门 系列导航地址http://www.cnblogs.com/fzrain/p/3490137.htm ...