一、Vector初始化:5种常用方式

​1. 默认构造​
创建空容器,适用于后续动态添加元素:

std::vector<int> vec;  // 空vector,size=0

2. 指定大小和初值​
预分配空间并初始化元素:

 
std::vector<int> vec(5);       // 5个0(int默认值)
std::vector<float> vec(3, 1.5); // 3个1.5

​3. 列表初始化(C++11)​
直接赋予初始值:

std::vector<char> vowels = {'a', 'e', 'i', 'o', 'u'};
 

4. 复制其他容器​
通过迭代器范围复制:

 
int arr[] = {1, 3, 5};
std::vector<int> vec(std::begin(arr), std::end(arr)); // 复制数组
std::vector<int> vec2(vec1);                         // 复制整个vector

​5. 使用assign()赋值​
清空现有元素并重新赋值:

 
vec.assign(4, 100);            // 4个100
vec.assign(oldVec.begin(), oldVec.end()); // 复制另一个容器的内容

二、增删改查:高效操作指南

​1. 添加元素​

  • ​尾部插入​​(高效,O(1)均摊):
     
    vec.push_back(10);     // 传统方式
    vec.emplace_back(20);  // 直接构造(避免拷贝,效率更高)

  • ​任意位置插入​​(谨慎使用,O(n)):
     
    vec.insert(vec.begin() + 2, 30);  // 在索引2处插入30
    vec.insert(vec.end(), {4, 5});    // 尾部插入多个元素

​2. 删除元素​

  • ​尾部删除​​(O(1)):
     
    vec.pop_back();  // 删除最后一个元素

  • ​任意位置删除​​(O(n)):
     
    vec.erase(vec.begin() + 1);          // 删除索引1处元素
    vec.erase(vec.begin(), vec.begin() + 2); // 删除前2个元素
    vec.clear();                         // 清空所有元素(容量不变)

​3. 修改元素​
随机访问修改(O(1)):

vec[0] = 100;                  // 无边界检查
vec.at(1) = 200;               // 有边界检查(越界抛异常)

​4. 查询元素​

 
int first = vec.front();       // 首元素
int last = vec.back();         // 末元素
int third = vec[2];            // 索引2处元素(无检查)
int fourth = vec.at(3);        // 索引3处元素(有检查)

⚠️ ​​性能警告​​:避免在头部/中间频繁插入删除,优先选择尾部操作!


三、判空操作:避免逻辑错误

​1. 一维Vector判空​
使用empty()代替size()==0(效率更高):

 
if (vec.empty()) {std::cout << "Vector is empty!";
}

​2. 二维Vector判空​
需检查外层和内层容器:

bool isMatrixValid(const vector<vector<int>>& mat) {if (mat.empty()) return false;          // 外层空for (const auto& row : mat) {if (row.empty()) return false;      // 内层存在空行}return true;
}

四、比较操作:规则与示例

​比较规则​​:

  • == / !=​:元素数量相同且对应位置值相等
  • < / <= / > / >=​:按字典序逐元素比较

​代码示例​​:

std::vector<int> a = {1, 2, 3};
std::vector<int> b = {1, 2, 4};cout << (a == b ? "Equal" : "Not equal");  // 输出:Not equal
cout << (a < b ? "a < b" : "a >= b");      // 输出:a < b(因 3 < 4)

五、二维数组:动态实现方案

​1. 初始化固定行列​

vector<vector<int>> matrix(3, vector<int>(4));      // 3行4列,默认值0
vector<vector<int>> matrix(2, vector<int>(3, -1));   // 2行3列,初始值-1

​2. 动态添加行/列​

 
matrix.push_back(vector<int>(5, 0));  // 添加一行5个0
matrix[0].resize(6);                 // 第一行扩展至6列

​3. 遍历与访问​

 
for (size_t i = 0; i < matrix.size(); ++i) {for (size_t j = 0; j < matrix[i].size(); ++j) {cout << matrix[i][j] << " ";}cout << endl;
}

💡 ​​适用场景​​:需动态调整行列数时优先使用,固定大小数组建议用原生数组。


总结:Vector核心要点

​维度​​关键点​​性能提示​
初始化预分配空间避免多次扩容reserve()减少内存重分配
增删改查尾部操作高效,中间操作昂贵优先用emplace_back替代push_back
判空多维容器需检查内层空empty()而非size()==0
比较字典序逐元素比较确保元素类型支持比较操作
二维数组灵活但内存非完全连续固定大小时考虑原生数组

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

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

相关文章

社会治理创新平台PPT(48页)

社会治理创新背景 社会治理创新旨在加强和完善基层社会管理和服务体系&#xff0c;提升政府效能&#xff0c;强化城乡社区自治和服务功能。自党的十六届四中全会提出“推进社会管理体制创新”以来&#xff0c;社会治理创新已成为政府工作的重要篇章。 社会治理创新现状与挑战…

论文笔记:Answering POI-Recommendation Questions using TourismReviews

2021 CIKM 1 intro 根据贝恩公司&#xff08;Bain & Company&#xff09;2019年的一份报告&#xff0c;旅行者在预订前通常会进行33至500次网页搜索 部分用户会访问超过50个旅游网站&#xff0c;三分之一的上网时间都用于与旅行相关的活动。在某些情况下&#xf…

带约束的高斯牛顿法求解多音信号分离问题

一、信号模型与优化问题建立 1. 复信号模型 设观测的复信号由两个单频复指数信号加噪声组成&#xff1a; x [ n ] A 0 e j ( 2 π f 0 n T s ϕ 0 ) A 1 e j ( 2 π f 1 n T s ϕ 1 ) w [ n ] , n 0 , 1 , … , N − 1 x[n] A_0 e^{j(2\pi f_0 n T_s \phi_0)} A_1 e…

Java并发编程中高效缓存设计的哲学

文章目录 引言详解缓存的设计和演进基于缓存存储运算结果锁分段散列减小锁粒度异步化提升处理效率原子化避免重复运算小结参考引言 本文将基于并发编程和算法中经典的哈希取模、锁分段、 异步化、原子化。这几个核心设计理念编写逐步推演出一个相对高效的缓存工具,希望对你有…

MATLAB的.mat文件

.mat文件是MATLAB的专有二进制数据文件格式&#xff0c;用于保存MATLAB工作空间中的变量和数据。 主要特点&#xff1a; 1. 存储内容&#xff1a; 各种类型的变量&#xff08;数组、矩阵、结构体、单元数组等&#xff09;函数句柄、对象稀疏矩阵多维数组 2. 文件特性&#…

ICM-20948 Wake on Motion功能开发全过程(7)

接前一篇文章:ICM-20948 Wake on Motion功能开发全过程(6) 探索工作 深入探索 上一回讲到,笔者在InvenSense官网上找到了实现Wake on Motion功能的指导文档。其中主要步骤如下: 本回就来结合文档中的步骤,详细讲解每一步。 (1)第1步 —— 初始化所有配置 注意,文档…

Dipal D1:数字人时代的全新人机关系形态

在科技不断突破的今天,虚拟与现实之间的界限正变得越来越模糊。Dipal D1 作为全球首款搭载2.5K曲面OLED显示屏的3D AI数字人硬件产品,不仅是一款情感陪伴设备,更是AI、AIGC、动漫文化与情感科技深度融合下的全新交互入口。它代表着“孤独经济”、“创作者经济”和“虚拟互动…

Linux离线编译安装nginx

Linux离线安装nginx 1.切换到root用户 #切换到root用户 su - #退出root用户 exit2.目录操作 #切到根目录 cd / #查看目录 ls #切目录 cd /home/... #到对应的目录下解压3.安装Nginx 在有网络的设备上下载以下文件&#xff1a; Nginx&#xff1a;从 nginx.org/en/download…

Qt PyQt与PySide技术-C++库的Python绑定

Qt PyQt与PySide技术-C库的Python绑定 一、概述二、区别于联系1、PyQt&#xff1a;Riverbank Computing的解决方案a、发展历程b、许可模式c、技术特点 2、PySide&#xff1a;Qt官方的Python绑定a、发展历程b、许可模式c、技术特点 三、对比许可证功能与兼容性社区与维护其他差异…

使用.detach()代替requires=False避免计算图错误

解决对一个对象多次BP更新时造成的RuntimeError: you can only change requires_grad flags of leaf variables.问题_解决对一个对象多次bp更新时造成的问题-CSDN博客 代码中存在一个特征需要参与辅助损失的计算&#xff0c;由于需要反复进行反向传播更新&#xff0c;计算图容易…

linux+docker+ollama+git常用指令

1、Linux命令 新建txt文件&#xff1a;touch xxx.txt 给txt文件夹权限&#xff1a;chmod x xxx.txt 查看日志&#xff1a;tail -f xxx.log / less xxx.log 根据关键字查看日志&#xff1a;grep "error" 文件名 查看端口状态&#xff1a;netstat -an|grep xxxxx 查看…

【八股消消乐】消息队列优化—系统架构设计

&#x1f60a;你好&#xff0c;我是小航&#xff0c;一个正在变秃、变强的文艺倾年。 &#x1f514;本专栏《八股消消乐》旨在记录个人所背的八股文&#xff0c;包括Java/Go开发、Vue开发、系统架构、大模型开发、具身智能、机器学习、深度学习、力扣算法等相关知识点&#xff…

WebSocket长连接在小程序中的实践:消息推送与断线重连机制设计

一、引言&#xff1a;为什么需要WebSocket长连接&#xff1f; 传统方案的痛点&#xff1a;HTTP轮询的低效性&#xff08;高延迟、高资源消耗&#xff09;小程序场景需求&#xff1a;实时消息推送&#xff08;如IM、直播弹幕、IoT设备状态同步&#xff09;技术选型对比&#xf…

MySQL索引使用指南:何时该为字段添加索引?

在MySQL的性能优化中&#xff0c;索引是最常用且有效的手段之一。但“索引不是万能药”——盲目添加索引可能导致写操作变慢、存储空间浪费&#xff0c;甚至引发索引失效问题。本文将结合原理与实战场景&#xff0c;帮你理清​​“何时该用索引”​​的核心判断逻辑。 一、先理…

AI时代关键词SEO优化

内容概要 在人工智能&#xff08;AI&#xff09;驱动的时代浪潮下&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;正迎来深刻变革&#xff0c;关键词策略已成为流量获取的核心战场。本文将系统剖析AI时代关键词优化的前沿方法&#xff0c;涵盖语义分析的精准研究、用户意…

GO 语言学习 之 代码风格

1. 命名规范 字母数字和下划线组成 以小写字母、大写字母或下划线开头 不允许包含标点符号、运算符、空白字符&#xff08;空格、TAB、换行&#xff09;等 采用驼峰命名法 &#xff08;大驼峰、小驼峰&#xff09; 见名知义&#xff1a;命名要有实际意义&#xff0c;易读性&am…

【软考高级系统架构论文】论云上自动化运维及其应用

论文真题 云上自动化运维是传统IT运维和 DevOps的延伸,通过云原生架构实现运维的再进化。云上自动化运维可以有效帮助企业降低IT运维成本,提升系统的灵活度,以及系统的交付速度,增强系统的可靠性,构建更加安全、可信、开放的业务平台。 请围绕“云上自动化运维及其应用”…

错误: 程序包androidx.fragment.app不存在 import android

错误: 程序包androidx.fragment.app不存在 import androidx.fragment.app.FragmentActivity; 这个是什么错?dependencies { //implementation fileTree(dir: libs, include: [*.jar]) implementation project(path: :libscan) //noinspection GradleCompatible implementation…

Java UDP Socket 实时在线刷卡扫码POS消费机门禁控制板服务端示例源码

本示例使用的设备&#xff1a;https://item.taobao.com/item.htm?spma21dvs.23580594.0.0.52de2c1bYG0BuO&ftt&id17021194999 一、获取本电脑所有网卡IP public static String getIP() {Enumeration<NetworkInterface> netInterfaces;ArrayList<String>…

MATLAB基础应用精讲-【数模应用】层次分析法(AHP)(附MATLAB和python代码实现)

目录 前言 算法原理 什么是层次分析法(AHP) 注意事项 基本原理 算法步骤 1建立层次结构 2构建判断矩阵 3计算权重向量 4一致性检验 SPSSAU AHP层次分析案例 1、背景 2、理论 3、操作 4、SPSSAU输出结果 5、文字分析 6、剖析 疑难解惑 数据如何录入? 如何…