(P27)vector动态数组:vector介绍 ,vector对象初始化 ,vector常用成员函数

2024-06-08 06:08

本文主要是介绍(P27)vector动态数组:vector介绍 ,vector对象初始化 ,vector常用成员函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1.vector介绍
    • 2.vector对象初始化
    • 3.vector常用成员函数

1.vector介绍

  • 标准库的vector类型
    (1)vector是同一种类型的对象的集合
    (2)vector的数据结构很像数组(元素存储的元素是连续的,但是空间是可以扩展的),能非常高效和方便地访问单个元素
    (3)vector是一个类模板(class template)
    (4)要使用vector必须包含相关头文件
#include <vector>
using std::vector;

2.vector对象初始化

  • vector类定义了好几种构造函数
vector<T>看成是一个类,T看成类型vector<T> v1;//vector保存类型为T的对象,默认构造函数v1为空vector<T> v2(v1);//v2是v1的一个副本,拷贝构造函数vector<T> v3(n,i);//v3包含n个值为i的元素,构造n个值为i的元素vector<T> v4(n);//v4含有值初始化的元素的n个副本,构造n个元素

3.vector常用成员函数

  • 往向量添加一些数据
    在这里插入图片描述
  • eg1:P27\01.cpp
#include <iostream>
#include <vector>
using namespace std;//vector<int>是一个模板类,把它看成一个类
typedef vector<int> INTVEC;void ShowVec(const INTVEC& v)
{//size()返回向量元素的个数unsigned int i;for (i=0; i<v.size(); i++){cout<<" "<<v[i]<<" ";//向量可以看成一个数组,它重载了[]运算符}cout<<endl;
}
//string也可以看成是一种容器,通常看成字符串类而已,它可以通过迭代器来遍历容器
//vector是STL中的一种容器,容器都支持迭代器的操作,它可以通过迭代器来遍历容器
//迭代器可以看成是容器的指针,可以看成是泛型程序指针,如果存放的元素是int,vector<int> ,该泛型程序指针就等价于int*
//但是其他容器并不是这么简单的等价的,其他的迭代器可能是一个类
//用迭代器来实现
void ShowVec(INTVEC& v)
{INTVEC::iterator it;//这里的iterator,就当作int*//for (it = v.begin(); it < v.end(); ++it)也行,但是任何一种容器都会重载!=运算符,而<运算符不一定,所以下面的更好//前提:iterator是一个类的情况,为什么不用it++?,因为后置运算符++会多一次临时对象的构造,效率低一些,不理解看:23cpp\23cpp\23cpp\Integer.cppfor (it = v.begin(); it != v.end(); ++it){cout << *it<<"";}cout<<endl;
}//如果使用带const,则iterator应该也是const
void ShowVec(const INTVEC& v)
{INTVEC::const_iterator it;//这里*it不能赋值了,*it = 4;不正确,*it会成为只读的,不能赋值for (it = v.begin(); it != v.end(); ++it){cout << *it<<"";}cout<<endl;
}int main(void)
{//string等价于basic_string<char>,string也是一个类模板,是类模板的实例,也可以看成一个类INTVEC v;//给定一个向量v,打印出来里面有哪些元素v.push_back(1);v.push_back(2);v.push_back(3);   ShowVec(v);// //size()返回向量元素的个数// unsigned int i;// for (i=0; i<v.size(); i++)// {//     cout<<" "<<v[i]<<" ";//向量可以看成一个数组,它重载了[]运算符// }// cout<<endl;return 0;
}
  • 测试:
    在这里插入图片描述
  • eg2:P27\02.cpp
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;//vector<int>是一个模板类,把它看成一个类
typedef vector<int> INTVEC;// void ShowVec(const INTVEC& v)
// {
//     //size()返回向量元素的个数
//     unsigned int i;
//     for (i=0; i<v.size(); i++)
//     {
//         cout<<" "<<v[i]<<" ";//向量可以看成一个数组,它重载了[]运算符
//     }
//     cout<<endl;
// }
// //string也可以看成是一种容器,通常看成字符串类而已,它可以通过迭代器来遍历容器
// //vector是STL中的一种容器,容器都支持迭代器的操作,它可以通过迭代器来遍历容器
// //迭代器可以看成是容器的指针,可以看成是泛型程序指针,如果存放的元素是int,vector<int> ,该泛型程序指针就等价于int*
// //但是其他容器并不是这么简单的等价的,其他的迭代器可能是一个类
// //用迭代器来实现
// void ShowVec(INTVEC& v)
// {
//     INTVEC::iterator it;//这里的iterator,就当作int*//     //for (it = v.begin(); it < v.end(); ++it)也行,但是任何一种容器都会重载!=运算符,而<运算符不一定,所以下面的更好
//     //前提:iterator是一个类的情况,为什么不用it++?,因为后置运算符++会多一次临时对象的构造,效率低一些,不理解看:23cpp\23cpp\23cpp\Integer.cpp
//     for (it = v.begin(); it != v.end(); ++it)
//     {
//         cout << *it<<"";
//     }
//     cout<<endl;
// }//如果使用带const,则iterator应该也是const
void ShowVec(const INTVEC& v)
{INTVEC::const_iterator it;//这里*it不能赋值了,*it = 4;不正确,*it会成为只读的,不能赋值for (it = v.begin(); it != v.end(); ++it){cout << *it<<"";}cout<<endl;
}int main(void)
{//string等价于basic_string<char>,string也是一个类模板,是类模板的实例,也可以看成一个类INTVEC v;//给定一个向量v,打印出来里面有哪些元素v.push_back(1);v.push_back(2);v.push_back(3);   v.push_back(4);v.push_back(5);v.push_back(3); // cout<<v.back()<<endl;//输出最后一个元素,但是并不弹出// v.pop_back();//会将最后一个元素弹出来ShowVec(v);// v.erase(v.begin()+2);//v里面的参数是迭代器//凡是涉及到迭代器,其区间都是[,)闭开的// v.erase(v.begin(), v.begin() + 2);//移除值=3的元素,remove就是个算法,end()实际指向的是最后一个3后面的元素,因为是闭开区间//remove(v.begin(), v.end(), 3);只是把3挪到最后面了//方法1v.erase(remove(v.begin(), v.end(), 3), v.end());//方法2,删除值于给定的元素值的方法,其他容器删除给定元素值也可以采用这种方式INTVEC::iterator it;for(it=v.begin(); it!=v.end();){if(*it == 3){it = v.erase(it);//erase返回的是当前删除元素的下一个元素}else++it;}ShowVec(v);return 0;}
  • 测试1:
    //string等价于basic_string<char>,string也是一个类模板,是类模板的实例,也可以看成一个类INTVEC v;//给定一个向量v,打印出来里面有哪些元素v.push_back(1);v.push_back(2);v.push_back(3);   cout<<v.back()<<endl;//输出最后一个元素,但是并不弹出v.pop_back();//会将最后一个元素弹出来ShowVec(v);

在这里插入图片描述

  • 测试2:
    //string等价于basic_string<char>,string也是一个类模板,是类模板的实例,也可以看成一个类INTVEC v;//给定一个向量v,打印出来里面有哪些元素v.push_back(1);v.push_back(2);v.push_back(3);   v.push_back(4);v.push_back(5);// cout<<v.back()<<endl;//输出最后一个元素,但是并不弹出// v.pop_back();//会将最后一个元素弹出来ShowVec(v);v.erase(v.begin()+2);//v里面的参数是迭代器ShowVec(v);

在这里插入图片描述
在这里插入图片描述

  • 测试3:
    //string等价于basic_string<char>,string也是一个类模板,是类模板的实例,也可以看成一个类INTVEC v;//给定一个向量v,打印出来里面有哪些元素v.push_back(1);v.push_back(2);v.push_back(3);   v.push_back(4);v.push_back(5);// cout<<v.back()<<endl;//输出最后一个元素,但是并不弹出// v.pop_back();//会将最后一个元素弹出来ShowVec(v);// v.erase(v.begin()+2);//v里面的参数是迭代器//凡是涉及到迭代器,其区间都是[,)的v.erase(v.begin(), v.begin() + 2);ShowVec(v);

在这里插入图片描述

  • 测试4:
    在这里插入图片描述

  • STL 六大组件:
    容器,迭代器,算法,函数对象,适配器(还分为容器适配器,迭代器适配器,算法适配器),内存分配器

  • 查找vector帮助手册的两种方式
    (1)方法1
    按下F1
    在这里插入图片描述

在这里插入图片描述

(2)方法2
在这里插入图片描述

这篇关于(P27)vector动态数组:vector介绍 ,vector对象初始化 ,vector常用成员函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1041380

相关文章

Kotlin运算符重载函数及作用场景

《Kotlin运算符重载函数及作用场景》在Kotlin里,运算符重载函数允许为自定义类型重新定义现有的运算符(如+-…)行为,从而让自定义类型能像内置类型那样使用运算符,本文给大家介绍Kotlin运算... 目录基本语法作用场景类对象数据类型接口注意事项在 Kotlin 里,运算符重载函数允许为自定义类型重

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中