vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。为了可以使用vector,必须在你的头文件中包含下面的代码:

#include <vector>

vector属于std命名域的,因此需要通过命名限定,如下完成你的代码:

using std::vector;     vector<int> v;

或者连在一起,使用全名:

std::vector<int> v;

建议使用全局的命名域方式:

using namespace std;

1.vector的声明

vector<ElemType> c;   创建一个空的vector

vector<ElemType> c1(c2); 创建一个vector c1,并用c2去初始化c1

vector<ElemType> c(n) ; 创建一个含有n个ElemType类型数据的vector;

vector<ElemType> c(n,elem); 创建一个含有n个ElemType类型数据的vector,并全部初始化为elem;

c.~vector<ElemType>(); 销毁所有数据,释放资源;

2.vector容器中常用的函数。(c为一个容器对象)

c.push_back(elem);   在容器最后位置添加一个元素elem

c.pop_back();            删除容器最后位置处的元素

c.at(index);                返回指定index位置处的元素

c.begin();                   返回指向容器最开始位置数据的指针

c.end();                      返回指向容器最后一个数据单元的指针+1

c.front();                     返回容器最开始单元数据的引用

c.back();                     返回容器最后一个数据的引用

c.max_size();              返回容器的最大容量

c.size();                      返回当前容器中实际存放元素的个数

c.capacity();               同c.size()

c.resize();                   重新设置vector的容量

c.reserve();                同c.resize()

c.erase(p);               删除指针p指向位置的数据,返回下指向下一个数据位置的指针(迭代器)

c.erase(begin,end)     删除begin,end区间的数据,返回指向下一个数据位置的指针(迭代器)

c.clear();                    清除所有数据

c.rbegin();                  将vector反转后的开始指针返回(其实就是原来的end-1)

c.rend();                     将vector反转后的结束指针返回(其实就是原来的begin-1)

c.empty();                   判断容器是否为空,若为空返回true,否则返回false

c1.swap(c2);               交换两个容器中的数据

c.insert(p,elem);          在指针p指向的位置插入数据elem,返回指向elem位置的指针

c.insert(p,n,elem);      在位置p插入n个elem数据,无返回值

c.insert(p,begin,end) 在位置p插入在区间[begin,end)的数据,无返回值

std::reverse(c.begin(), c.end());//反转c中元素顺序

下面是个人在工作中使用vector的一些总结

 //使用的结构体
typedef struct tagDataStruct
{
int nVal;
double dVal;
std::string strstdString;
CString strCString;
}DataStruct; bool _CompareFun (const DataStruct& item1, const DataStruct& item2)
{//结构体排序方法
//bool bRet = (item1.nVal < item2.nVal) ? true : false;//升序排列
bool bRet = (item1.nVal > item2.nVal) ? true : false;//降序排列
return bRet;
}
bool findx(DataStruct &task)
{//结构体查找方法
return task.strstdString == "";
} void CLoadDllDemoDlg::OnBnClickedButton16()
{//STL
std::vector<std::string>vecString;
for(int i = ; i < ; i++)
{
std::string str = "demo";
int n = atoi(str.c_str());
std::string strAdd;
std::stringstream ssCov;
ssCov<<i;
ssCov>>strAdd;
str.append(strAdd);
vecString.push_back(str);
}
/////////////////////////////////int数据///////////////////////////////////////////////////
std::vector<int>vecInt;
for(int i = ; i > ; i--)
{//添加数据
vecInt.push_back(i);
} /*排序*/
std::sort(vecInt.begin(), vecInt.end()); /*查找数据*/
std::vector<int>::iterator itFind = find(vecInt.begin(), vecInt.end(), );
if(itFind != vecInt.end())
{//找到数据
std::string strTip = "提示";
} /*删除数据*/
if(itFind != vecInt.end())
{
vecInt.erase(itFind);
}
/*遍历数据使用传统方法or迭代器*/
for(UINT i = ; i < vecInt.size(); i++)
{
int nVal = vecInt[i];
}
std::vector<int>::iterator it;
for(it = vecInt.begin(); it != vecInt.end(); it++)
{
int nVal = *it;
}
/*清空数据*/
vecInt.clear();//ps:只是清空数据
vecInt.swap(std::vector<int>());//ps:清空数据,并且清理内存 /////////////////////结构体vector///////////////////////////////////
std::vector<DataStruct>vecDataStruct;
for(int p = ; p < ; p++)
{
DataStruct datastruct;
datastruct.nVal = p;
datastruct.dVal = double(p);
std::stringstream ssCov;
ssCov<<p;
ssCov>>datastruct.strstdString; datastruct.strCString.Format(_T("%d"), p);
vecDataStruct.push_back(datastruct);
}
/*排序*/
std::sort(vecDataStruct.begin(), vecDataStruct.end(), _CompareFun);
/*结构体查找数据*/
DataStruct dataStr;
std::vector<DataStruct>::iterator itStruct = find_if(vecDataStruct.begin(), vecDataStruct.end(), findx);
if(itStruct != vecDataStruct.end())
{//找到
std::string strFind = "找到";
}
}
 void CLoadDllDemoDlg::OnBnClickedButton33()
{//vector删除
std::vector<int>vecDemo;
for(int i = ; i < ; i++)
{
vecDemo.push_back(i);
}
//while循环删除
vector<int>::iterator itEarse=vecDemo.begin();
while(itEarse!=vecDemo.end())
{
if(*itEarse==)
{
itEarse=vecDemo.erase(itEarse);
}
else
{
++itEarse;
}
} //for循环删除
vector<int>::iterator ite;
for(ite=vecDemo.begin();ite!=vecDemo.end();)
{
if(*ite==)
{
ite=vecDemo.erase(ite);
}
else
{
++ite;
}
}
std::reverse(vecDemo.begin(), vecDemo.end());
}

C++ STL vector使用总结的更多相关文章

  1. C++ STL vector容器学习

    STL(Standard Template Library)标准模板库是C++最重要的组成部分,它提供了一组表示容器.迭代器.函数对象和算法的模板.其中容器是存储类型相同的数据的结构(如vector, ...

  2. STL vector

    STL vector vector是线性容器,它的元素严格的按照线性序列排序,和动态数组很相似,和数组一样,它的元素存储在一块连续的存储空间中,这也意味着我们不仅可以使用迭代器(iterator)访问 ...

  3. STL vector用法介绍

    STL vector用法介绍 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和f ...

  4. STL vector+sort排序和multiset/multimap排序比较

    由 www.169it.com 搜集整理 在C++的STL库中,要实现排序可以通过将所有元素保存到vector中,然后通过sort算法来排序,也可以通过multimap实现在插入元素的时候进行排序.在 ...

  5. STL vector 用法介绍

    介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...

  6. STL vector使用方法介绍

    介绍 这篇文章的目的是为了介绍std::vector,怎样恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...

  7. stl——vector详解

    stl——vector详解 stl——vector是应用最广泛的一种容器,类似于array,都将数据存储于连续空间中,支持随机访问.相对于array,vector对空间应用十分方便.高效,迭代器使ve ...

  8. C++STL vector详解(杂谈)

    介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if()和for_each()中的使用.通 ...

  9. C++ stl vector介绍

    转自: STL vector用法介绍 介绍 这篇文章的目的是为了介绍std::vector,如何恰当地使用它们的成员函数等操作.本文中还讨论了条件函数和函数指针在迭代算法中使用,如在remove_if ...

  10. 浅谈C++ STL vector 容器

    浅谈C++ STL vector 容器 本篇随笔简单介绍一下\(C++STL\)中\(vector\)容器的使用方法和常见的使用技巧.\(vector\)容器是\(C++STL\)的一种比较基本的容器 ...

随机推荐

  1. 我的Java开发学习之旅------>Java经典排序算法之二分插入排序

    一.折半插入排序(二分插入排序) 将直接插入排序中寻找A[i]的插入位置的方法改为采用折半比较,即可得到折半插入排序算法.在处理A[i]时,A[0]--A[i-1]已经按关键码值排好序.所谓折半比较, ...

  2. python数据分析之:数据清理,转换,合并,重塑(一)

    DataFrame合并: merge运算是将一个或多个键将行链接起来.来看下面的这个例子: In [5]: df1=DataFrame({'key':['b','b','a','c','a','a', ...

  3. MySQL多表查询一网打尽

    现有四张表 mysql> select * from student; +------+--------+-------+-------+ | s_id | s_name | s_age | s ...

  4. Java多线程系列 基础篇10 wait/notify/sleep/yield/join

    1.Object类中的wait()/notify()/notifyAll() wait(): 让当前线程处于Waiting状态并释放掉持有的对象锁,直到其他线程调用此对象的线程notify()/not ...

  5. Kbuntu16.04利用快捷键调用终端Konsole

    之前用其他linux,可以按ctrl alt t三个键快速调用终端.但是我用Kbuntu16.04这个版本的时候却不行.于是跑去自定义了一下下. System Settings  -->  Wo ...

  6. RQNOJ 169 最小乘车费用:水dp

    题目链接:https://www.rqnoj.cn/problem/169 题意: 给出行驶1-10公里的费用(所有车一样),可以倒车,问行驶n公里的最小费用. 题解: 大水题... (=´ω`=) ...

  7. L87

    Fear Makes Art More Engaging Emmanuel Kant spoke often about the sublime, and specifically how art b ...

  8. OpenCV——PS 滤镜算法之极坐标变换到平面坐标

    // define head function #ifndef PS_ALGORITHM_H_INCLUDED #define PS_ALGORITHM_H_INCLUDED #include < ...

  9. 每天一个linux命令(1):man命令

    版权声明 更新:2017-04-19博主:LuckyAlan联系:liuwenvip163@163.com声明:吃水不忘挖井人,转载请注明出处! 1 文章介绍 本文介绍了Linux下命令man. 2 ...

  10. 「USACO08DEC」「LuoguP2921」在农场万圣节Trick or Treat on the Farm(tarjan

    题意翻译 题目描述 每年,在威斯康星州,奶牛们都会穿上衣服,收集农夫约翰在N(1<=N<=100,000)个牛棚隔间中留下的糖果,以此来庆祝美国秋天的万圣节. 由于牛棚不太大,FJ通过指定 ...