Vector学习

在c++中,vector是一个十分有用的容器。

作用:它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据。

vector在C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库。

特别注意:

使用vector需要注意以下几点:

1、如果你要表示的向量长度较长(需要为向量内部保存很多数),容易导致内存泄漏,而且效率会很低;

2、Vector作为函数的参数或者返回值时,需要注意它的写法:

   double Distance(vector<int>&a, vector<int>&b) 其中的“&”绝对不能少!!!

1 、基本操作

(1)头文件#include<vector>.

(2)创建vector对象,vector<int> vec;

(3)尾部插入数字:vec.push_back(a);

(4)使用下标访问元素,cout<<vec[0]<<endl;记住下标是从0开始的。

(5)使用迭代器访问元素.

vector<int>::iterator it;

for(it=vec.begin();it!=vec.end();it++)

    cout<<*it<<endl;

(6)插入元素:    vec.insert(vec.begin()+i,a);在第i+1个元素前面插入a;

(7)删除元素:    vec.erase(vec.begin()+2);删除第3个元素

vec.erase(vec.begin()+i,vec.end()+j);删除区间[i,j-1];区间从0开始

(8)向量大小:vec.size();

(9)清空:vec.clear();

二维数组的使用:

  1. #include "stdafx.h"  
  2. #include <cv.h>  
  3. #include <vector>   
  4. #include <iostream>   
  5. using namespace std;  
  6. int main()  
  7. {  
  8.     using namespace std;  
  9.     int out[3][2] = { 1, 2,   
  10.              3, 4,  
  11.             5, 6 };  
  12.     vector <int*> v1;  
  13.   
  14.     v1.push_back(out[0]);  
  15.     v1.push_back(out[1]);  
  16.     v1.push_back(out[2]);  
  17.   
  18.     cout << v1[0][0] << endl;//1  
  19.     cout << v1[0][1] << endl;//2  
  20.     cout << v1[1][0] << endl;//3  
  21.     cout << v1[1][1] << endl;//4  
  22.     cout << v1[2][0] << endl;//5  
  23.     cout << v1[2][1] << endl;//6  
  24.   
  25.     return 0;  
  26. }  

 

 

首先看一下原c++栈的方法的基本用法:

  1. push(): 向栈内压入一个成员;
  2. pop(): 从栈顶弹出一个成员;
  3. empty(): 如果栈为空返回true,否则返回false;
  4. top(): 返回栈顶,但不删除成员;
  5. size(): 返回栈内元素的大小;
posted on 2018-03-14 09:54  米兰达莫西  阅读(190)  评论(0编辑  收藏  举报