vector使用过程中的一些坑(持续更)

简介: vector使用过程中的一些坑(持续更)

vector使用过程中的一些坑(持续更)

1.vector为空时不能通过下标标赋值,如:

#include <iostream>
#include <vector>
using namespace std;
int main()
{
    vector<int> v;
    v[0] = 1;
    return 0;
}

v初始为空所以出错

但只要初始vector有容量通过下标赋值就可以:

#include<bits/stdc++.h>
using namespace std;
int main()
{
  vector<int>a(1);
  a[2]=1;
  cout<<a[2];
}

就能成!

2.vector通过数组下标访问时注意vector为空时不能通过下标标赋值,如:

#include<bits/stdc++.h>
using namespace std;
int main()
{
  vector<int>a;
  a[2]=1;
  cout<<a[2];
}

v初始为空所以出错

但只要初始vector有容量通过下标赋值就可以:

#include<bits/stdc++.h>
using namespace std;
int main()
{
  vector<int>a(1);
  a[2]=1;
  cout<<a[2];
}

3.vector通过数组下标访问时注意这个元素是存在的,不然会出现运行内存错误,如:

#include<bits/stdc++.h>
using namespace std;
int main()
{
  vector<int>a(10);
  a[2]=1;
  a[10]=1;
  cout<<a[10];
}

a[10]是越界的,这段代码访问了vector末尾以后的元素,这将可能导致很危险的结果,但系统不会报错。

建议使用at函数访问如:

vector<int> v(10,0);
cout<<v.at(11)<<endl;

以下的代码将更加安全,取代试图访问内存里非法值的作法,at() 函数能够辨别出访问是否越界并在越界的时候中止程序。

4.创建类似二维数组的vector:

vector<int> v[N];

它创建了一个由第1个类型的N个vector组成的静态数组。

v[0]现在是一个和v[1]完全不同的vector。注意,v[0]是vector而不是vector中的元素。如果我们想向第1个vector push一个值,可以通过 v[0].push_back(val)。为了访问那个元素我们可以通过 v[0][0]来访问(类似2维矩阵)。

例:

vector <int> v2[n]; 
    v2[0].push_back(1); 
    v2[0].push_back(20); 
    cout << '\n'; 
    for(int i = 0; i < v2[0].size(); i++ ) 
       cout << v2[0][i] << " ";

**5.**vector容器可以通过还可以通过以下2种构造函数初始化:

vector<int> v(v2);
vector<int> v = v2;

v从v2 复制数据。

目录
相关文章
|
机器学习/深度学习 人工智能 监控
机器视觉:技术原理、应用与未来发展
机器视觉:技术原理、应用与未来发展
|
存储 安全 搜索推荐
几种常见教育视频点播系统建设方案和成本分享
教育行业视频点播系统建设方案分享,点量软件团队专注视频点播十五年,无论是局域网、公网点播视频建设均可。终端可应用于手机、电视盒、智能电视等多种设备,在不同的设备中都可以流畅播放。
324 4
几种常见教育视频点播系统建设方案和成本分享
|
XML JSON 前端开发
Bpmn.js 进阶指南之原理分析与模块改造(下)
Bpmn.js 进阶指南之原理分析与模块改造
2273 2
|
机器学习/深度学习 PyTorch 数据处理
数据增强与 DataLoader:提升模型泛化能力的策略
【8月更文第29天】在深度学习中,数据的质量和数量对于模型的性能至关重要。数据增强是一种常用的技术,它通过对原始数据进行变换(如旋转、缩放、裁剪等)来生成额外的训练样本,从而增加训练集的多样性和规模。这有助于提高模型的泛化能力,减少过拟合的风险。同时,`DataLoader` 是 PyTorch 中一个强大的工具,可以有效地加载和预处理数据,并支持并行读取数据,这对于加速训练过程非常有帮助。
1215 1
|
算法 Linux 调度
操作系统的心脏:深入理解进程调度
本文将深入探讨操作系统中最核心的概念之一——进程调度。通过简明扼要的语言和具体实例,帮助读者理解进程调度的基本原理、算法及其在现代操作系统中的应用。我们将从简单的轮转调度到复杂的多级反馈队列调度,一步步揭开这个复杂系统的面纱。
374 4
|
JavaScript Java 应用服务中间件
SpringMVC静态资源处理
SpringMVC静态资源处理
|
IDE Unix 测试技术
CMake基础(10)使用ninja构建
CMake基础(10)使用ninja构建
2271 1
|
缓存 边缘计算 负载均衡
如何理解CDN?说说实现原理?
CDN(内容分发网络)是提升网络访问速度的关键技术,通过在全球或全国范围内设立边缘服务器,将内容缓存到靠近用户的地方。当用户访问网站时,DNS返回CNAME,引导用户连接到最近的CDN节点,而非直接到源站。CDN的负载均衡系统依据用户位置、运营商、节点负载等因素选择最佳边缘节点提供服务,而缓存系统则存储常用资源以提高命中率,减少回源请求。高命中率使得CDN能显著提高网站性能,降低网络拥塞。
4436 0
|
并行计算 安全 编译器
【C/C++ 编译相关 gcc】一次搞懂GCC编译选项:优化代码、调试程序必备!
【C/C++ 编译相关 gcc】一次搞懂GCC编译选项:优化代码、调试程序必备!
1319 0
|
设计模式 缓存 安全
【Java设计模式 - 创建型模式1】单例模式
【Java设计模式 - 创建型模式1】单例模式
107 0

热门文章

最新文章