【黑马程序员】STL之vector常用操作

文章目录

  • vector
    • vector 基本概念
      • 功能
      • vector与普通数组区别
      • vector动态扩展
    • 在这里插入图片描述
      • 函数原型
      • 代码示例
    • vector容器的赋值操作
      • 函数原型
      • 代码示例
    • vector容量和大小
      • 函数原型
      • 代码示例
    • vector插入删除
      • 函数原型
      • 代码示例
    • vector容器数据存取
      • 函数原型
      • 代码示例
    • swap使用
      • 代码示例
    • reserver
      • 代码示例

vector

vector 基本概念

功能

  • vector数据结构和数组非常相似,也称为单端数组

vector与普通数组区别

  • 数组是静态空间,而vector可以动态扩展

vector动态扩展

  • 开辟内存更大的空间,然后将原数据拷贝到新空间,释放原空间

  • vector容器是支持随机访问的迭代器

在这里插入图片描述

vector的构造函数

  • 创建vector容器

函数原型

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(const vector<int> &v) {
    for (int i = 0; i < v.size(); i++) {
        cout << v[i] << " ";
    }
    cout << endl;
}

void test() {
    // 默认构造函数
    vector<int> v1;
    for (int i = 0; i < 10; i++) {
        v1.push_back(i);
    }
    printVector(v1);
    // 利用区间的方式进行构造
    vector<int> v2(v1.begin(), v1.end());
    printVector(v2);
    // 利用n个elem方式构造
    vector<int> v3(10, 1);
    printVector(v3);
    // 使用拷贝构造方式
    vector<int> v4(v1);
    printVector(v4);
}

int main() {
    test();
    return 0;
}

vector容器的赋值操作

  • 给vector容器进行赋值

函数原型

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(const vector<int> &v) {
    for (int i = 0; i < v.size(); i++) {
        cout << v[i] << " ";
    }
    cout << endl;
}

void test() {
    // 默认构造函数
    vector<int> v1;
    for (int i = 0; i < 10; i++) {
        v1.push_back(i);
    }
    printVector(v1);
    // 使用   operator=赋值
    vector<int> v2 = v1;
    printVector(v2);
    // 使用assign将指定区间的数据进行考本    [first, last)
    vector<int> v3;
    v3.assign(v1.begin(), v1.end());
    printVector(v3);
    // 使用assign将n个elem赋值拷贝
    vector<int> v4;
    v4.assign(10, 4);
    printVector(v4);
}

int main() {
    test();
    return 0;
}

vector容量和大小

  • 对vector容器的容量和大小操作

函数原型

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(vector<int> &v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

void test() {
    vector<int> v1;
    for (int i = 0; i < 10; i++) {
        v1.push_back(i);
    }
    printVector(v1);
    cout << "容量:" << v1.capacity() << endl;
    cout << "是否为空:" << v1.empty() << endl;
    cout << "元素个数:" << v1.size() << endl;
    // resize 变短则超出部分会被删除
    v1.resize(3);
    printVector(v1);
    // resize 变长则以给定值填充
    v1.resize(5);
    printVector(v1);
    // resize 变长则以给定值填充
    v1.resize(8, 3);
    printVector(v1);
}

int main() {
    test();
    return 0;
}

vector插入删除

函数原型

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(vector<int> &v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

void test() {
    // 默认构造函数
    vector<int> v1;
    // 尾插
    for (int i = 0; i < 5; i++) {
        v1.push_back(i);
    }
    printVector(v1);
    // 尾删
    v1.pop_back();
    printVector(v1);
    // 第一个参数需要使用迭代器
    v1.insert(v1.begin(), 10);
    // 在指定位置开始插入n个x
    v1.insert(v1.begin(), 3, 20);
    // 删除, 传入的是迭代器
    v1.erase(v1.begin());
    v1.erase(v1.begin(), v1.begin() + 5);
    vector<int> v2 = v1;
    printVector(v2);
    // 清空
    v1.clear();
    printVector(v1);
    v2.erase(v2.begin(), v2.end());
    printVector(v2);
}

int main() {
    test();
    return 0;
}

vector容器数据存取

函数原型

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(vector<int> &v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

void test() {
    // 默认构造函数
    vector<int> v1;
    for (int i = 0; i < 10; i++) {
        v1.push_back(i);
    }
    printVector(v1);
    cout << "使用[]获取:" << v1[5] << endl;
    cout << "使用at方法获取:" << v1.at(5) << endl;
    cout << "获取第一个位置:" << v1.front() << endl;
    cout << "获取最后一个位置" << v1.back() << endl;
}

int main() {
    test();
    return 0;
}

swap使用

  • 实际使用场景:快速收缩容量

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(vector<int> &v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

void test() {
    // 默认构造函数
    vector<int> v1;
    for (int i = 0; i < 10; i++) {
        v1.push_back(i);
    }
    cout << "交换前:" << endl;
    printVector(v1);
    vector<int> v2;
    for (int i = 10; i > 0; i--) {
        v2.push_back(i);
    }
    printVector(v2);
    v1.swap(v2);
    cout << "交换后:" << endl;
    printVector(v1);
    printVector(v2);
}

// 实际用途:收缩容量
void test1() {
    vector<int> v;
    v.resize(1000000, 1);
    cout << v.size() << endl;
    cout << v.capacity() << endl;
    v.resize(3, 2);
    cout << v.size() << endl;
    cout << v.capacity() << endl;
    // 使用匿名对象的方式快速收缩容量   
    vector<int>(v).swap(v);
    cout << v.size() << endl;
    cout << v.capacity() << endl;
}

int main() {
    test();
    test1();
    return 0;
}

reserver

  • 预分配空间,减少使用中空间的开辟和拷贝

代码示例

#include <iostream>
#include <vector>

using namespace std;

void printVector(vector<int> &v) {
    for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {
        cout << *it << " ";
    }
    cout << endl;
}

// 不预分配容量
void test() {
    int num = 0;
    int *p = NULL;
    vector<int> v;
    for (int i = 0; i < 1000000; i++) {
        if (p != &v[0]) {
            num++;
            p = &v[0];
        }
        v.push_back(i);
    }
    cout << num << endl;
}

// 预分配容量
void test1() {
    int num = 0;
    int *p = NULL;
    vector<int> v;
    // 提前预先分配1000000空间,不需要在开辟空间    
    v.reserve(1000000);
    for (int i = 0; i < 1000000; i++) {
        if (p != &v[0]) {
            num++;
            p = &v[0];
        }
        v.push_back(i);
    }
    cout << num << endl;
}

int main() {
    test();
    test1();
    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

当面试问你接口测试时,不要再说不会了!

很多人会谈论接口测试。到底什么是接口测试&#xff1f;如何进行接口测试&#xff1f;这篇文章会帮到你。 01 前端和后端 在谈论接口测试之前&#xff0c;让我们先明确前端和后端这两个概念。 前端是我们在网页或移动应用程序中看到的页面&#xff0c;它由 HTML 和 CSS 编写…

【Golang数组】

数组 数组的引入内存分析数组遍历数组的初始化方式注意事项二维数组二维数组的遍历 数组的引入 【1】练习引入&#xff1a; package main import "fmt" func main(){//实现的功能&#xff1a;给出五个学生的成绩&#xff0c;求出成绩的总和&#xff0c;平均数&…

邮件系统国产化,U-Mail助推企业数字化建设

在当今数字化时代&#xff0c;企业管理和办公效率的提升已成为企业发展的关键。随着信息技术的迅速发展&#xff0c;邮件系统成为许多企业提高办公效率和管理水平的重要工具。然而&#xff0c;长期以来&#xff0c;国内企业在邮件系统方面主要依赖于国外产品&#xff0c;这不仅…

Another Redis Desktop Manager工具连接集群

背景&#xff1a;使用Another Redis Desktop Manager连接redsi集群 win10安装 使用 下载 某盘&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1dg9kPm9Av8-bbpDfDg9DsA 提取码&#xff1a;t1sm 使用

【前端素材】推荐优质后台管理系统Skydash平台模板(附源码)

一、需求分析 后台管理系统&#xff08;或称作管理后台、管理系统、后台管理平台&#xff09;是一种专门用于管理网站、应用程序或系统后台运营的软件系统。它通常由一系列功能模块组成&#xff0c;为管理员提供了管理、监控和控制网站或应用程序的各个方面的工具和界面。以下…

防御保护----内容安全

八.内容安全--------------------------。 IAE引擎&#xff1a; IAE引擎里面的技术&#xff1a;DFI和DPI技术--- 深度检测技术 DPI --- 深度包检测技术--- 主要针对完整的数据包&#xff08;数据包分片&#xff0c;分段需要重组&#xff09;&#xff0c;之后对 数据包的内容进行…

C/C++有序数组中插入元素

一、不利用指针 代码&#xff1a; int i; void insert(int ,int , int ); int main() {int a[100];int n, m;cout<<"输入数组元素个数\n";cin >> n;cout << "输入数组元素\n";for (i 0; i < n; i) {cin >> a[i];}cout <&…

Less预处理器教程

学习源码可以看我的个人前端学习笔记 (github.com):qdxzw/frontlearningNotes 觉得有帮助的同学&#xff0c;可以点心心支持一下哈 一、Less介绍 less官方文档 lesscss.org/ less中文文档 less.bootcss.com/ less是一种css预处理器&#xff0c;它扩展了css语言&#xff0c…

【Java程序设计】【C00267】基于Springboot的在线考试系统(有论文)

基于Springboot的在线考试系统&#xff08;有论文&#xff09; 项目简介项目获取开发环境项目技术运行截图 项目简介 本系统是基于Springboot的在线考试系统&#xff1b;本系统主要分为管理员、教师和学生三种角色&#xff1b; 管理员登录系统后&#xff0c;可以对首页&#x…

广联达协同办公系统GetAllData接口存在敏感信息泄露漏洞 附POC软件

@[toc] 广联达协同办公系统GetAllData接口存在敏感信息泄露漏洞 附POC软件 免责声明:请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失,均由使用者本人负责,所产生的一切不良后果与文章作者无关。该文…

LeetCode69. x 的平方根(C++)

LeetCode69. x 的平方根 题目链接代码 题目链接 https://leetcode.cn/problems/sqrtx/description/ 代码 class Solution { public:int mySqrt(int x) {int right x, left 0, ans -1;while(left < right){long long mid left (right - left) / 2;if(mid * mid <…

Python算法题集_全排列

Python算法题集_全排列 题46&#xff1a;全排列1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【标记数组递归】2) 改进版一【指针递归】3) 改进版二【高效迭代模块】4) 改进版三【高效迭代模块极简代码】 4. 最优算法5. 相关资源 本文为Python…

猫头虎分享已解决Bug || Vue中的TypeError: Cannot read property ‘name‘ of undefined 错误

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

<Elon Musk>里面的思考

从Elon Musk身上学到的三个重要人生课程 Introduction 在这篇博文中&#xff0c;我将分享我从Elon Musk身上学到的三个重要人生课程。结合了一些个人的经历&#xff0c;以及视频内容中与三位朋友的交流&#xff0c;希望能给大家带来一些启发和帮助。 第一课&#xff1a;如何…

基于springboot+vue的二手图书交易平台(源码+论文)

文章目录 目录 文章目录 前言 一、功能设计 二、功能实现 前台系统功能模块分为 后台系统功能模块分为 三、库表设计 四、论文 前言 在互联网上所有产品的分类信息中&#xff0c;电子类的产品信息无疑是最丰富的&#xff0c;一大批电子资讯类网站从中国互联网诞生初期就开始为…

算法--贪心

这里写目录标题 区间问题区间选点引入算法思想例题代码 最大不相交区间的数量算法思想例题代码 一级目录二级目录二级目录二级目录 一级目录二级目录二级目录二级目录 区间问题 区间选点 引入 区间问题会给定几个区间&#xff0c;之后要求我们在数轴上选取尽量少的点&#xf…

【MySQL】表的约束 -- 详解

表中一定要有各种约束&#xff0c;通过约束让我们在未来插入数据库表中的数据是符合预期的。约束本质是通过技术手段倒逼程序员插入正确的数据&#xff0c;反过来站在 MySQL 的角度&#xff0c;凡是插入进来的数据都是符合数据约束的。约束的最终目标&#xff1a;保证数据的完整…

ffmpeg的pcm、yuv小知识点

ffmpeg的pcm、yuv小知识点 pcm、yuv保存调用&#xff0c;写个通用工具方法&#xff0c;平时快速保存&#xff0c;和调用方便查看自己bug ffmpeg的AVFrame存储 yuv 调用方法 保存方法 void save_yuv420p_file(unsigned char *y_buf , unsigned char *u_buf,unsigned char *…

Leetcode刷题笔记题解(C++):6. Z 字形变换

思路&#xff1a;遍历时候需要更新步进长度 到达0行的时候步进长度为1&#xff1b;到达最后一行numRows-1行的时候步进长度为-1&#xff1b;代码如下所示&#xff1a; class Solution { public:string convert(string s, int numRows) {//如果字符串长度为1或者所给行数为1 …

嵌入式Qt 实现用户界面与业务逻辑分离

一.基本程序框架一般包含 二.框架的基本设计原则 三.用户界面与业务逻辑的交互 四.代码实现计算器用户界面与业务逻辑 ICalculator.h #ifndef _ICALCULATOR_H_ #define _ICALCULATOR_H_#include <QString>class ICalculator { public:virtual bool expression(const QSt…