C++:vector的初始化定义和赋值方法总结

文章目录

  • 前言
    • C++:vector的初始化定义和赋值方法总结,对几种方法进行总结归纳,并对一些初始化方法的应用场景和细节进行说明
  • 一、vector初始化和赋值方法
    • 1.不带参数的构造函数初始化
    • 2.带参数的构造函数初始化
    • 3.利用数组地址初始化
    • 4.通过同类型的vector初始化
    • 5.通过insert初始化
    • 6.通过copy函数赋值
    • 7.细节注意:
  • 总结


前言

C++:vector的初始化定义和赋值方法总结,对几种方法进行总结归纳,并对一些初始化方法的应用场景和细节进行说明

一、vector初始化和赋值方法

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

vector<int> scores; 
//初始化一个size为0的vector,方便创建动态分配的数组,可再后续通过push_back进行添加元素

2.带参数的构造函数初始化

//初始化size,但每个元素值为默认值
vector<int> abc(10);    //初始化了10个默认值为0的元素
//初始化size,并且设置初始值
vector<int> cde(101);    //初始化了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);

5.通过insert初始化

//insert初始化方式将同类型的迭代器对应的始末区间(左闭右开区间)内的值插入到vector中
vector<int> a(6,6);
vecot<int> b;
//将a[0]~a[2]插入到b中,b.size()由0变为3
b.insert(b.begin(), a.begin(), a.begin() + 3);

insert也可通过数组地址区间实现插入

int a[6] = {6,6,6,6,6,6};
vector<int> b;
//将a的所有元素插入到b中
b.insert(b.begin(), a, a+6);

此外,insert还可以插入m个值为n的元素

//在b开始位置处插入6个6
b.insert(b.begin(), 6, 6);

6.通过copy函数赋值

vector<int> a(5,1);
int a1[5] = {2,2,2,2,2};
vector<int> b(10);

/*将a中元素全部拷贝到b开始的位置中,注意拷贝的区间为a.begin() ~ a.end()的左闭右开的区间*/
copy(a.begin(), a.end(), b.begin());

//拷贝区间也可以是数组地址构成的区间
copy(a1, a1+5, b.begin() + 5);

7.细节注意:

1.vector abc(10);定义vector大小是圆括号(),不是【】
2.vectorabc(num);num未知情况下,系统会给abc一个很大的空间,且值为0,不利于后续操作,不建议此初始化方法!

//如下,不建议,会出错
int num;
vector<int> scores(num);
vector<int>::iterator pd; //定义vector的double类型的迭代器,迭代器就是广义指针
cin >> num;
for (int i = 0; i < num; i++)//scores获取值
{
     scores.push_back(i);
 }
for (pd = scores.begin(); pd != scores.end(); pd++)//循环输出
{
     /* code */
     cout << "*pd =" << *pd << "  ";
 }     
 //会出现输出死循环bug!

原因:初始化scores时,num未知,系统给了vector一个很大的空间且全为0,当输入num为多少时,pd都不会等于scores.end(),所以循环不会停止,进入了死循环。
解决方法:采用本文第一种初始化方法,并进行push_back()赋值。

总结

本文对vector的初始化和赋值方法进行总结和归纳,防止此知识点遗忘,方便进行查找回顾。

本文参考:
https://blog.csdn.net/yjunyu/article/details/77728410?utm_medium=distribute.pc_relevant.none-task-blog-2defaultbaidujs_baidulandingword~default-4-77728410-blog-121061681.pc_relevant_3mothn_strategy_recovery&spm=1001.2101.3001.4242.3&utm_relevant_index=7

你可能感兴趣的:(编程提高,c++,算法,数据结构)