【C++】 vector 数组/向量

文章目录

  • 【 1. vector 的声明与初始化 】
    • 1.1 vector 的声明
    • 1.2 vector 的初始化
      • 1.2.1 构造一个空的 vector
      • 1.2.2 指定数量初值的方式初始化 vector
      • 1.2.3 迭代器的方式初始化
      • 1.2.4 构造一个相同的 vector
  • 【 2. vector 的相关操作 】
    • 2.1 插入元素
      • 2.1.1 在vector的末尾插入新元素
      • 2.1.2 在迭代器的前面插入新元素
      • 2.1.3 覆盖原有的 vector
    • 2.2 删除元素

  • vector数组是可以 存放任意数据类型 动态数组
    和普通数组类似,可以通过下标对数组中的元素进行引用。
  • 使用vector数组要在 头文件中加 #include<vector>
  • vectors 包含着一系列连续存储的元素,其行为和数组类似。访问 vector 中的任意元素或从末尾添加元素都可以在常量级时间复杂度内完成,而查找特定值的元素所处的位置或是在vector中插入元素则是线性时间复杂度。

【 1. vector 的声明与初始化 】

1.1 vector 的声明

  • 声明
vector<int> vec;//声明一个存放int型的向量vec

1.2 vector 的初始化

1.2.1 构造一个空的 vector

  • 基本语法
    构造一个空的vector。
vector<int> myvector();
  • 举例1
    构造一个空的 vector myvector。
#include<iostream>
#include<vector>using namespace std;
int main()
{ vector<int> myvector();return 0;
}

在这里插入图片描述

1.2.2 指定数量初值的方式初始化 vector

  • 基本语法
    构造一个初始放入num个值为val的元素的vector。
  vector( size_type num, const TYPE &val );
  • 举例1
    构造一个 5 个 3 的 vector。这里 myvec.size() 返回 myvec 元素数量大小
#include<iostream>
#include<vector>using namespace std;
int main()
{ vector<int> myvec(5, 3);for (int j=0;j<myvec.size();++j)cout << myvec[j]<<endl;return 0;
}

在这里插入图片描述

1.2.3 迭代器的方式初始化

  • 基本语法
    构造一个初始值为 [start,end) 区间元素的vector。
vector( input_iterator start, input_iterator end );
  • 举例1
    将 myvec 初始化为 [地址a,地址a+3)的元素 。
#include<iostream>
#include<vector>using namespace std;
int main()
{ int a[5] = { 1, 2, 3, 4, 5 };vector <int>myvec( a,a+3 );for (int j=0;j<myvec.size();++j)cout << myvec[j]<<endl;return 0;
}

在这里插入图片描述

  • 举例2
    将 myvec 初始化为 [地址&a[1],地址&a[4])的元素 。
#include<iostream>
#include<vector>using namespace std;
int main()
{ int a[5] = { 1, 2, 3, 4, 5 };vector<int> myvec(&a[1], &a[4]);for (int j=0;j<myvec.size();++j)cout << myvec[j]<<endl;return 0;
}

在这里插入图片描述

1.2.4 构造一个相同的 vector

  • 基本语法
    构造一个与 AnthorVector 相同的vector 。
vector( const vector &AnthorVector);
  • 举例1
    构造一个与 myvec 相同的 myvec2 。
#include<iostream>
#include<vector>using namespace std;
int main()
{ int a[5] = { 1, 2, 3, 4, 5 };vector<int> myvec(&a[1], &a[4]);vector <int>myvec2(myvec);for (int j=0;j<myvec.size();++j)cout << myvec2[j]<<endl;return 0;
}

在这里插入图片描述

【 2. vector 的相关操作 】

在这里插入图片描述
下面给出几个常用的操作及案例。

2.1 插入元素

2.1.1 在vector的末尾插入新元素

  • 基本语法
    在 myvec 的末尾添加元素newvalue。
myvec.push_back(newvalue);
  • 举例1
    在 myvec 的末尾添加元素1。
#include<vector>using namespace std;
int main()
{vector<int> myvec(5, 3);myvec.push_back(1);for (int j = 0; j <myvec.size(); ++j)cout << myvec[j] << endl;return 0;
}

在这里插入图片描述

2.1.2 在迭代器的前面插入新元素

  • 基本语法
    在 myvec 的前面添加元素newvalue。
vector<int>::iterator it;
it=vec.begin();
vec.insert(it,newvalue);
  • 举例1
    在 myvec 的前面添加元素1。
#include<iostream>
#include<vector>
using namespace std;
int main()
{vector<int> myvec(5, 3);vector<int>::iterator it;it = myvec.begin();myvec.insert(it, 1);for (int j = 0; j <myvec.size(); ++j)cout << myvec[j] << endl;return 0;
}

在这里插入图片描述

2.1.3 覆盖原有的 vector

  • 基本语法
    在vector中加入NewNum个NewValue元素,同时清除掉以前的元素。
vec.assign(NewNum,NewValue);//现在vec中只有NewNum个NewValue
  • 举例1
    现在vector中只有2个1。
#include<iostream>
#include<vector>
using namespace std;
int main()
{vector<int> myvec(5, 3);myvec.assign(2, 1);//现在vector中只有2个1for (int j = 0; j <myvec.size(); ++j)cout << myvec[j] << endl;return 0;
}

在这里插入图片描述

2.2 删除元素

  • 基本语法
//删除最后一个元素
vec.pop_back();//删除指定位置的元素
vec.erase(vec.begin());//删除第一个位置的元素值//清除所有元素
vec,clear();
  • 举例1
    删除 myvec 的最后一个元素
#include<iostream>
#include<vector>
using namespace std;
int main()
{vector<int> myvec(5, 3);myvec.pop_back();for (int j = 0; j <myvec.size(); ++j)cout << myvec[j] << endl;return 0;
}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/577488.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS实战开发-如何实现一个自定义抽奖圆形转盘

介绍 本篇Codelab是基于画布组件、显式动画&#xff0c;实现的一个自定义抽奖圆形转盘。包含如下功能&#xff1a; 通过画布组件Canvas&#xff0c;画出抽奖圆形转盘。通过显式动画启动抽奖功能。通过自定义弹窗弹出抽中的奖品。 相关概念 Stack组件&#xff1a;堆叠容器&am…

DHCP设置二

华为ensp模拟实验 准备工作 需要设备&#xff1a;路由器 一台 交换机 两台 pc两台 ip划分网段 &#xff1a;192.168.10.0 24 192.168.20.0 24 当我们准备好之后就可以开机了 开机实验 点击菜单栏小三角&#xff0c;开启设备。 输入system-view进入系统视图&#x…

C语言结合体和枚举的魅力展现

前言 ✨✨欢迎&#x1f44d;&#x1f44d;点赞☕️☕️收藏✍✍评论 个人主页&#xff1a;秋邱’博客 所属栏目&#xff1a;人工智能 &#xff08;感谢您的光临&#xff0c;您的光临蓬荜生辉&#xff09; 引言: 前面我们已经讲了结构体的声明&#xff0c;自引用&#xff0c;内存…

【全套源码教程】基于SpringBoot+MyBatis框架的智慧生活商城系统的设计与实现

目录 前言 需求分析 可行性分析 技术实现 后端框架&#xff1a;Spring Boot 持久层框架&#xff1a;MyBatis 前端框架&#xff1a;Vue.js 数据库&#xff1a;MySQL 功能介绍 前台功能拓展 商品详情单管理 个人中心 秒杀活动 推荐系统 评论与评分系统 后台功能拓…

【C++】map set

文章目录 1. 关联式容器2. 键值对3. 树形结构的关联式容器3.1 set3.1.1 set 的介绍3.1.2 set 的使用 3.2 map3.2.1 map 的介绍3.2.2 map 的使用 3.3 multiset3.3.1 multuset 的介绍3.3.2 multiset 的使用 3.4 multimap3.4.1 multimap 的介绍3.4.2 multimap 的使用 1. 关联式容器…

Git版本管理使用手册 - 8 - 合并分支、解决冲突

合并整个开发分支 切换到本地test分支&#xff0c;选择右下角远程开发分支&#xff0c;选择Merge into Current。然后提交到远程test仓库。 合并某次提交的代码 当前工作区切换成test分支&#xff0c;选择远程仓库中的dev开发分支&#xff0c;选择需要合并的提交版本右击&a…

github项目名称变更sourcetree如何同步

github项目名称变更sourcetree如何同步 方法1:删除本地仓库 重新从URL克隆 方法2:修改远程地址链接 1.打开项目所在文件夹的终端 2.删除本地关联的这个远程仓库origin git remote rm origin 3.关联修改名字后的远程仓库地址 git remote add origin <新的远程仓库地址&…

CentOS使用Docker部署Halo并结合内网穿透实现公网访问本地博客

文章目录 1. Docker部署Halo1.1 检查Docker版本如果未安装Docker可参考已安装Docker步骤&#xff1a;1.2 在Docker中部署Halo 2. Linux安装Cpolar2.1 打开服务器防火墙2.2 安装cpolar内网穿透 3. 配置Halo个人博客公网地址4. 固定Halo公网地址 本文主要介绍如何在CentOS 7系统使…

网络稳定性(蓝桥省赛)

0网络稳定性 - 蓝桥云课 (lanqiao.cn) 知识点&#xff1a;克鲁斯卡尔生成树&#xff0c;lca&#xff0c;倍增 最小生成树的模板&#xff1a;最小生成树【模板】-CSDN博客 题解代码如下&#xff1a; #include<bits/stdc.h> using namespace std; const int N3e5100; co…

基于java的高校校园点餐系统

开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7 数据库工具&#xff1a;Navicat11 开发软件&#xff1a;eclipse/myeclipse/idea Maven包&#xff1a;Maven3.3.9 系统展示 前…

台灯护眼灯哪个牌子好?护眼灯十大品牌推荐

随着近视率的上升&#xff0c;越来越多的人开始重视眼睛健康&#xff0c;尤其是学生群体面临着巨大的学习压力。家长们也意识到良好的眼睛保护至关重要&#xff0c;开始关注护眼台灯的作用。在选择护眼灯时&#xff0c;家长们常常会陷入犹豫&#xff0c;不知道哪个品牌更可靠。…

Linux安装JDK1.8

前言&#xff1a;本文内容为实操记录&#xff0c;仅供参考&#xff01; Ubuntu配置多版本jdk&#xff1a;http://t.csdnimg.cn/0UcTf 一、下载 官方下载&#xff08;需要注册Oracle账号&#xff09;&#xff1a; Java Downloads | Oracle 国内镜像下载&…