opencv03-补充-vector的操作

opencv03-补充-vector的操作

参考:https://www.runoob.com/w3cnote/cpp-vector-container-analysis.html

构造方法(具体介绍看API文档)

class Student {public:private:string name;};int main() {vector<int>();vector<int> v1;vector<Student> v2; // 存放自定义类vector<string> v3;vector<vector<int> >;  //注意空格。这里相当于二维数组int a[n][n];vector<int> v5 = {1, 2, 3, 4, 5}; //列表初始化,注意使用的是花括号vector<string> v6 = {"hi", "my", "name", "is", "lee"};vector<int> v7(5, -1); //初始化为-1,-1,-1,-1,-1。第一个参数是数目,第二个参数是要初始化的值vector<string> v8(3, "hi");vector<int> v9(10); //默认初始化为0vector<int> v10(4); //默认初始化为空字符串return 0;
}

增加元素和访问元素

int main() {vector<int> v1;v1.push_back(2);v1.push_back(3);v1.push_back(4);// 使用索引访问元素for (int i = 0; i < v1.size(); i++) {cout << v1[i] << endl;//v1[i] = 100;//cout << v1[i] << endl;}/*reference at(int pos):返回pos位置元素的引用reference front():返回首元素的引用reference back():返回尾元素的引用iterator begin():返回向量头指针,指向第一个元素*/cout << ".................." << endl;cout << v1.at(2) << endl; // 返回pos位置元素的引用cout << v1.front() << endl; // 返回首元素的引用int a = v1.back(); //返回尾元素的引用cout << a << endl;// 使用迭代器访问元素vector<string> v6 = {"hi", "my", "name", "is", "lee"};for (vector<string>::iterator iter = v6.begin(); iter != v6.end(); iter++) {cout << *iter << endl;//下面两种方法都都可以检查迭代器是否为空cout << (*iter).empty() << endl;cout << iter->empty() << endl;}// 使用迭代器反向访问元素for (vector<string>::reverse_iterator iter = v6.rbegin(); iter != v6.rend(); iter++) {cout << *iter << endl;}return 0;
}

插入函数、大小函数、删除函数

#include <vector>
#include <array>using namespace std;
using namespace cv;int main() {std::vector<int> demo{1, 2};//第一种格式用法: 向量中迭代器指向元素前增加一个元素xdemo.insert(demo.begin() + 1, 3);//{1,3,2}//第二种格式用法: 向量中迭代器指向元素前增加n个相同的元素xdemo.insert(demo.end(), 2, 5);//{1,3,2,5,5}//第三种格式用法:向量中迭代器指向元素前插入另一个相同类型向量的[first,last)间的数据std::array<int, 3> test{7, 8, 9};demo.insert(demo.end(), test.begin(), test.end());//{1,3,2,5,5,7,8,9}//第四种格式用法:向量中迭代器指向元素前插入一个数组demo.insert(demo.end(), {10, 11});//{1,3,2,5,5,7,8,9,10,11}for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}// 输出结果为:1 3 2 5 5 8 9 10 11cout << "size:" << demo.size() << endl; //10cout << "capacity:" << demo.capacity() << endl; //10cout << "max_size:" << demo.max_size() << endl; //4611686018427387903cout << "empty:" << demo.empty() << endl; //0 判断向量是否为空,若为空,则向量中无元素//demo.clear(); // 清空向量中所有元素//cout << "empty:" << demo.empty() << endl; // 1demo.pop_back(); // 删除向量中最后一个元素for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}// 输出结果为:1 3 2 5 5 7 8 9 10cout << "---------------------------------" << endl;// iterator erase(iterator it):删除向量中迭代器指向元素demo.erase(demo.begin() + 1);for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}//输出结果为: 1 2 5 5 7 8 9 10cout << "---------------------------------" << endl;//iterator erase(iterator first,iterator last):删除向量中[first,last)中元素demo.erase(demo.begin() + 1, demo.end() - 2);for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}//输出结果为: 1 9 10return 0;
}

其他函数


int main() {std::vector<int> demo{12, 32, 23, 58, 52, 17, 28, 39, 10};// 1. 排序sort(demo.begin(), demo.end());for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}// 输出结果为: 10 12 17 23 28 32 39 52 58cout << endl;// 倒置reverse(demo.begin(), demo.end());for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}// 输出结果为: 58 52 39 32 28 23 17 12 10// void assign(int n,const T& x):设置向量中前n个元素的值为x,并将集合的size设置为:ndemo.assign(3, -1); //cout << "size:" << demo.size() << endl; //size:3for (int i = 0; i < demo.size(); i++) {cout << demo[i] << " ";}// 输出结果为: -1 -1 -1cout << endl;//void assign(const_iterator first,const_iterator last):向量中[first,last)中元素设置成当前向量元素std::vector<int> demo2{12, 32, 23, 58, 52, 17, 28, 39, 10};demo2.assign(demo.begin(), demo.end());for (int i = 0; i < demo2.size(); i++) {cout << demo2[i] << " ";}return 0;
}

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

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

相关文章

【kubernetes】k8s单master集群环境搭建及kuboard部署

k8s入门学习环境搭建 学习于许大仙: https://www.yuque.com/fairy-era k8s官网 https://kubernetes.io/ kuboard官网 https://kuboard.cn/ 基于k8s 1.21.10版本 前置环境准备 一主两从&#xff0c;三台虚拟机 CPU内存硬盘角色主机名IPhostname操作系统4C16G50Gmasterk8s-mast…

JVM面试题--JVM组成

JVM是什么 Java Virtual Machine Java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 运行流程 什么是程序计数器&#xff1f; 程序计数器&#xff1a;线程私有的&#xff0c;内部保存的字节码的行号。用于记录正在执行的字节码指令的地址。 我们知道ja…

第4章 .NetCore程序通过花生壳实现内网穿透

.NetCore程序在调试环境中都是基于内网的&#xff0c;但是.NetCore程序如果需要集成微信第3方认证程序&#xff0c;由于微信第3方认证程序需要外网把认证后的数据信息&#xff0c;通过外网传输到.NetCore程序中&#xff0c;所以必须先实现把内网地址映射为外网地址这样的操作叫…

【电影推荐系统】数据爬取、数据加载进MongoDB数据库

概览 本篇主要介绍数据来源、数据加载进数据库过程 1 数据获取 使用Scrapy爬取豆瓣电影数据&#xff0c;然后利用movielens数据集来造一份rating数据。 1.1 数据集获取 数据集获取&#xff1a;选取movielens 数据集&#xff1a;movielens官网数据集包括&#xff1a;movies…

【数据挖掘torch】 基于LSTM电力系统负荷预测分析(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Istio 安全 授权管理AuthorizationPolicy

这个和cka考试里面的网络策略是类似的。它是可以实现更加细颗粒度限制的。 本质其实就是设置谁可以访问&#xff0c;谁不可以访问。默认命名空间是没有AuthorizationPolicy---允许所有的客户端访问。 这里是没有指定应用到谁上面去&#xff0c;有没有指定使用哪些客户端&#…

SE-Net注意力机制

📌本次任务:了解SE-Net原理 SE-Net 是 ImageNet 2017(ImageNet 收官赛)的冠军模型,是由WMW团队发布。具有复杂度低,参数少和计算量小的优点。且SENet 思路很简单,很容易扩展到已有网络结构如 Inception 和 ResNet 中。(这篇论文是2019年的,应该是后续做了更新) 一…

12-3_Qt 5.9 C++开发指南_创建和使用静态链接库

第12章中的静态链接库和动态链接库介绍&#xff0c;都是以UI操作的方式进行&#xff0c;真正在实践中&#xff0c;可以参考UI操作产生的代码来实现同样的功能。 文章目录 1. 创建静态链接库1.1 创建静态链接库过程1.2 静态链接库代码1.2.1 静态链接库可视化UI设计框架1.2.2 qw…

Netty3 和Netty4区别

Netty3 和Netty4区别 目录概述需求&#xff1a; 设计思路实现思路分析1.Netty3和Netty4区别2.demo 拓展实现 参考资料和推荐阅读 Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better resul…

【华为OD机试】荒岛求生【2023 B卷|100分】

【华为OD机试】-真题 !!点这里!! 【华为OD机试】真题考点分类 !!点这里 !! 题目描述 有一个荒岛,只有左右两个港口,只有一座桥连接这两个港口,现在有一群人需要从两个港口逃生, 有的人往右逃生,有的往左逃生,如果两个人相遇,则PK,体力值大的能够打赢体力值小的, …

Java学习资料的推荐

以下是一些Java学习资料的推荐&#xff1a; 1. Java入门教程&#xff1a;https://www.runoob.com/java/java-tutorial.html 2. 阿里巴巴Java开发手册&#xff1a;https://github.com/alibaba/p3c/blob/master/README_zh_CN.md 3. Java编程思想&#xff08;Thinking in Java&…

SLA探活工具EaseProbe

工具介绍 EaseProbe可以做三种工作&#xff1a;探测、通知和报告。 项目地址&#xff1a;https://github.com/megaease/easeprobe 1、安装 [rootlocalhost ]# yum -y install unzip go [rootlocalhost ]# unzip easeprobe-main.zip [rootlocalhost ]# cd easeprobe-main [r…

数据结构--算法的时间复杂度和空间复杂度

文章目录 算法效率时间复杂度时间复杂度的概念大O的渐进表示法计算实例 时间复杂度实例 常见复杂度对比例题 算法效率 算法效率是指算法在计算机上运行时所消耗的时间和资源。这是衡量算法执行速度和资源利用情况的重要指标。 例子&#xff1a; long long Fib(int N) {if(N …

linux的内嵌汇编代码

/* C语言实现MCR指令 */ #define __STRINGIFY(x) #x #define __MCR(coproc, opcode_1, src, CRn, CRm, opcode_2) \ __ASM volatile ("MCR " __STRINGIFY(p##coproc) ", " __STRINGIFY(opcode_1) ", " \ "%0, &…

Mybatis

文章目录 MyBatis1、概述1.2、特性1.3、安装1.4、对比 2、搭建Mybatis2.1、创建一个Maven项目2.2、然后使用project structure确定java版本2.3、setting>build->build tools>maven&#xff0c;配置maven仓库、镜像、目录2.4、设置打包方式&#xff08;子模组&#xff…

MySQL的备份与还原

MySQL的备份与还原 1、MySQL的备份说明 热备&#xff1a; 在数据库正在运行下进行备份&#xff0c;备份期间&#xff0c;数据库读写均可以正常进行&#xff1b; 温备&#xff1a; 数据库可用性弱于热备&#xff0c;备份期间&#xff0c;数据库只能进行读操作&#xff0c;不…

hcip——BGP实验

要求 1.搭建toop 2.地址规划 路由器AS接口地址R11 loop0:1.1.1.1 24 loop1 : 192.168.1.1 24 g0/0/0 12.0.0.1 24 R22 64512 g0/0/0: 12.0.0.2 24 g/0/01: 172.16.0.2 19 g0/0/2: 172.16.96.2 19 R32 64512g0/0/0: 172.16.0.3 19 g0/0/1:1…

版本兼容问题——C++ 字符串库(std::basic_string::stoi)

软件开发过程中经常会存在版本更迭问题,对于如何做好版本之间的兼容性,相信也是八仙过海,各有神通。 那么,当我们确定了一个版本,怎么比较版本之间的差异呢? 且看如下代码: int CompareVersion(const std::string& strCurVersion, const std::string& strHis…

Linux systemctl命令详解

systemctl是Linux中用于管理系统服务&#xff08;例如防火墙等&#xff09;的命令行工具。它是一个功能强大的工具&#xff0c;可以启动、停止、重启、查看状态、启用或禁用系统服务&#xff0c;以及管理系统的单元&#xff08;units&#xff09;和套接字&#xff08;sockets&a…

chrome扩展控制popup页面动态切换

文章目录 1、通过控制元素的显示隐藏达到popup页面切换的效果2、通过监听页面重新加载完成不同popup的切换3、直接修改popup页面location.href&#xff0c;无需刷新页面 1、通过控制元素的显示隐藏达到popup页面切换的效果 下面在mv2版本的API下完成 实际上通过控制页面元素实…