vector数组创建及备用知识

一、vector数组创建

1、一维数组

一维数组定义为Vector<int> a,就是 int* a=new int[size];

(1)不带参数的构造函数初始化

//初始化一个size为0的vector
vector<int> abc;

(2)带参数的构造函数初始化

//初始化size,但每个元素值为默认值
vector<int> abc(10); //初始化了10个默认值为0的元素

//初始化size,并且设置初始值
vector<int> cde(10,1); //初始化了10个值为1的元素

(3)通过数组地址初始化

int a[5] = {1,2,3,4,5}; //通过数组a的地址初始化,注意地址是从0到5(左闭右开区间)
vector<int> b(a, a+5);

(4)通过同类型的vector初始化

vector<int> a(5,1); //通过a初始化
vector<int> b(a);

2、二维数组
参考了两篇博客:
https://blog.csdn.net/baidu_31818237/article/details/52080920
https://blog.csdn.net/u010159842/article/details/51325185

//二维数组定义为Vector<Vector<int> > a 就是int **a = new int*[size];

一、参考一
做题的时候想当然了,申请二维数组直接这样写:

//注意> >间的空格,不然会被编译器认为是>>而报错。
vector<vector<int> > vec;
vec[0][0] = 1;  //error 

很明显的越界访问,此时的vec空有其名,没有空间。

此时的vec.size为0,空有其名,没有空间大小,并不能用来访问元素,此时可以向vec中添加一维向量
方案一:

vec.push_back(vector<int>());

vector()的()中可以添加参数vector(m,n),其中m为一维向量的大小,默认为0,n为一维向量中的元素,默认为0.
方案二:

vec.resize(1);

vec.resize()有两个参数(m,n),m为vec的大小,n为vector(),也就是申明vec时vector<>vec中尖括号之间的东西。
到此我们也可看出,vector二维数组其实就是一个嵌套,因此我们也可以这样理解:

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
#define type vector < int >
#define type_size 6     //大小自定
#define type_value 3    //大小自定
#define vec_size 6      //大小自定
#define vec_value type(type_size,type_value)//参数可不要
int main()
{
    vector<type> vec(vec_size,vec_value);//申明二维向量,vec_size指定大小,vec_value指定初始值,两参数默认为0,都可不要
    vec.push_back(vec_value);            //添加一个一维向量
    vec.resize(vec_size, vec_value);     //重新指定二维向量的大小,不足的用vec_vauet(一维向量)填充
    return 0;
}

3、n维数组
其实就是二维数组

#include <iostream> 
#include<vector>
using namespace std;

int main()
{
	const int dim=4;
	vector<vector<int> > array_two;
	
	for(int i=0; i<dim; ++i)//放4行
	{
		vector<int> column;//定义每行的容器
		array_two.push_back(column);//放入每行的容器
	}

   for(int i=0,num=1; i<dim; ++i)//行的顺序
       for(int j=0; j<dim; ++j)//列的顺序
	   {
  			array_two[i].push_back(num++);//依次放入存储的数据,array_two[i]是第i行的容器
	   }
		
	for(int i=0; i<dim; ++i,putchar('\n'))
		for(int j=0; j<dim; ++j)
		    printf("%d ",array_two[i][j]); //显示16个数

	for(int i=0;i<dim;++i)//从每行开始析构
		array_two[i].~vector();
		
	array_two.~vector();

	return 0;
}

二、vector其它知识

1、C++通过容器vector遍历数组两种方式

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
template<typename T>
void printEle(T value)
{
	cout << value << endl;
}
void test()
{
	vector<int> v;
	for (int i = 0; i < 10; i++)
	{
		v.push_back(i);
	}
	//第一种遍历方式
	//使用for循环和迭代器遍历容器
	//begin()返回的迭代器指向容器中的首元素
	//end()返回的迭代器指向容器中尾元素的下一个位置
	for (vector<int>::iterator iter = v.begin(); iter != v.end(); iter++)
	{
		cout << *iter << endl;
	}
	//第二种遍历方式
	//需要包含头文件<algorithm>
	//第三个参数需要传入函数名,即对容器中元素的操作方法
	for_each(v.begin(), v.end(), printEle<int>);
}
int main()
{
	test();
}

for_each的底层实现:

// FUNCTION TEMPLATE for_each
template <class _InIt, class _Fn>
_Fn for_each(_InIt _First, _InIt _Last, _Fn _Func) { // perform function for each element [_First, _Last)
    _Adl_verify_range(_First, _Last);
    auto _UFirst      = _Get_unwrapped(_First);
    const auto _ULast = _Get_unwrapped(_Last);
    for (; _UFirst != _ULast; ++_UFirst) {
        _Func(*_UFirst);
    }

    return _Func;
}

2、C++中对vector所有元素求和
两种实现方式:
一种是自己写循环求和。
一种是使用numeric中的accumulate函数进行求和。

#include <iostream>
#include <vector>
#include <numeric>
using namespace std;

template<typename T>
T SumVector(vector<T>& vec)
{
    T res = 0;
    for (size_t i=0; i<vec.size(); i++)
    {
        res += vec[i];
    }
    return res;
}

int main()
{
    vector<int> v = { 1, 2, 3, 4, 5 };
    cout << "sum1: " << SumVector(v) << endl;
    cout << "sum2: " << accumulate(v.begin(), v.end(), 0) << endl;
    cout << "sum3: " << accumulate(v.begin(), v.end(), 5) << endl;
    return 0;
}

输出结果:

sum1: 15
sum2: 15
sum3: 20

3、vector作为参数的三种传参方式
c++中常用的vector容器作为参数时,有三种传参方式,分别如下(为说明问题,用二维vector):

function1(std::vector<std::vector<int> > vec),传值
function2(std::vector<std::vector<int> >& vec),传引用
function3(std::vector<std::vector<int> >* vec),传指针
注意,三种方式分别有对应的const形式,不在此讨论。

三种方式对应的调用形式分别为:

function1(vec),传入值
function2(vec),传入引用
function3(&vec),传入地址

三种方式的效果分别为:
会发生拷贝构造
不会发生拷贝构造
不会发生拷贝构造

验证程序:

#include <iostream>
  2 #include <vector>
  3 
  4 using namespace std;
  5 
  6 void function1(std::vector<std::vector<int> > vec)
  7 {
  8     cout<<"-----------------------------------------"<<endl;
  9     //打印vec的地址
 10     cout<<"function1.&vec:"<<&vec<<endl;
 11     //打印vec[i]的地址(即第一层vector的地址)
 12     cout<<"function1.&vec[i]:"<<endl;
 13     for(int i=0;i<2;i++)
 14         cout<<&vec[i]<<endl;
 15     //打印vec的各元素地址
 16     cout<<"function1.&vec[i][j]:"<<endl;
 17     for(int i=0;i<2;i++)
 18     {
 19         for(int j=0;j<3;j++)
 20             cout<<&vec[i][j]<<" ";
 21         cout<<endl;
 22     }
 23     cout<<"---------------------------"<<endl;
 24     //打印vec的各元素值
 25     cout<<"function1.vec[i][j]:"<<endl;
 26     for(int i=0;i<2;i++)
 27     {
 28         for(int j=0;j<3;j++)
 29             cout<<vec[i][j]<<" ";
 30         cout<<endl;
 31     }
 32 }
 33 void function2(std::vector<std::vector<int> >& vec)
 34 {
 35     cout<<"-----------------------------------------"<<endl;
 36     //打印vec的地址
 37     cout<<"function2.&vec:"<<&vec<<endl;
 38     //打印vec[i]的地址(即第一层vector的地址)
 39     cout<<"function2.&vec[i]:"<<endl;
 40     for(int i=0;i<2;i++)
 41         cout<<&vec[i]<<endl;
 42     //打印vec的各元素地址
 43     cout<<"function2.&vec[i][j]:"<<endl;
 44     for(int i=0;i<2;i++)
 45     {
 46         for(int j=0;j<3;j++)
 47             cout<<&vec[i][j]<<" ";
 48         cout<<endl;
 49     }
 50     cout<<"---------------------------"<<endl;
 51     //打印vec的各元素值
 52     cout<<"function2.vec[i][j]:"<<endl;
 53     for(int i=0;i<2;i++)
 54     {
 55         for(int j=0;j<3;j++)
 56             cout<<vec[i][j]<<" ";
 57         cout<<endl;
 58     }
 59 
 60 }
 61 void function3(std::vector<std::vector<int> > *vec)
 62 {
 63     cout<<"-----------------------------------------"<<endl;
 64     //打印vec的地址
 65     cout<<"function3.&vec:"<<vec<<endl;
 66     //打印vec[i]的地址(即第一层vector的地址)
 67     cout<<"function3.&vec[i]:"<<endl;
 68     for(int i=0;i<2;i++)
 69         cout<<&(*vec)[i]<<endl;
 70     //打印vec的各元素地址
 71     cout<<"function3.&vec[i][j]:"<<endl;
 72     for(int i=0;i<2;i++)
 73     {
 74         for(int j=0;j<3;j++)
 75             cout<<&(*vec)[i][j]<<" ";
 76         cout<<endl;
 77     }
 78     cout<<"---------------------------"<<endl;
 79     //打印vec的各元素值
 80     cout<<"function3.vec[i][j]:"<<endl;
 81     for(int i=0;i<2;i++)
 82     {
 83         for(int j=0;j<3;j++)
 84             cout<<(*vec)[i][j]<<" ";
 85         cout<<endl;
 86     }
 87 }
 88 
 89 int main()
 90 {
 91     //创建2*3的vector容器v,初始值均初始化为0 1 2 1 2 3
 92     std::vector<std::vector<int> > v(2,std::vector<int>(3,0));
 93     for(int i=0;i<2;i++)
 94     {
 95         for(int j=0;j<3;j++)
 96             v[i][j]=i+j;
 97     }
 98 
 99     //打印v的地址
100     cout<<"&v:"<<&v<<endl;
101     //打印v[i]的地址(即第一层vector的地址)
102     cout<<"&v[i]:"<<endl;
103     for(int i=0;i<2;i++)
104         cout<<&v[i]<<endl;
105     //打印v的各元素地址
106     cout<<"&v[i][j]:"<<endl;
107     for(int i=0;i<2;i++)
108     {
109         for(int j=0;j<3;j++)
110             cout<<&v[i][j]<<" ";
111         cout<<endl;
112     }
113 
114     cout<<"---------------------------"<<endl;
115     //打印v的各元素值
116     cout<<"v[i][j]:"<<endl;
117     for(int i=0;i<2;i++)
118     {
119         for(int j=0;j<3;j++)
120             cout<<v[i][j]<<" ";
121         cout<<endl;
122     }
123 
124     function1(v);
125     function2(v);
126     function3(&v);
127 
128     return 0;
129 }

在这里插入图片描述

4、vector作为函数返回值用法
在实际应用过程中,我们经常需要保存一系列的数据,有可能是一个值,点等,这时我们会用到vector。
如下所示:

vector<int>
vector<float>
与opencv结合使用时可能还会有:
vector<Point>,vector<vec4i>,vector<vector<Point>>等

有时候我们需要将vector作为一个函数的返回值。
使用方法如下所示:
我们将函数返回值设定为bool类型,vector作为函数的参数,添加引用,保存数据。

我们想表达的是如下意思:我们输入的数据为Image1,想返回Center向量,但是这样写会报不知名的错

vector<Point> ComputeCenter(Mat&image1,vector<Point>Center)

正确使用方式:

bool ComputeCenter(Mat&image1,vector<Point>&Center)
{
    return true;
}

这里我们使用的是它的引用。

例子

//定义一个计算数字的函数,返回计算后的vector numbers
bool computeNumber(int num, vector<int>&numbers)
{
    for (int i = 0; i < num; i++)
    {
        numbers.push_back(i + 10);
    }

    return true;

}
int main()
{

    int num = 10;
    vector <int> numbers;
    computeNumber(10, numbers);//调用函数,调用之后,numbers就一直存在
    //后面我们就可以直接引用
    for (vector<int>::iterator it = numbers.begin(); it != numbers.end(); it++) {numbers
        cout << *it << endl;
    }
    return 0;
}

//最后返回 10,11,....19
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值