当前位置: 首页 > news >正文

STL、Vector和Set的讲解和例题分析

STL       

STL(Standard Template Library,标准模板库)是C++标准库的一部分,它提供了一系列通用的编程组件,包括容器、迭代器、算法和函数对象等。STL是C++中实现泛型编程的核心,它允许程序员使用模板编写与数据类型无关的代码。

STL的特点:

1.泛型编程:STL基于模板,支持泛型编程,允许编写与数据类型无关的代码。

2.容器:STL提供了多种容器,如vectorlistmapset等,用于存储和管理数据。

3.迭代器:STL使用迭代器作为访问容器元素的通用方法,它提供了一种统一的方式来遍历和操作容器。

4.算法:STL包含了一系列算法,如排序、搜索、复制等,这些算法可以应用于不同的容器和数据类型。

5.函数对象:STL中的函数对象(也称为仿函数)是重载了函数调用运算符的类,它们可以像函数一样被调用。

常见用法:

1.容器:使用STL容器来存储和管理数据集合,如vectorlistmapset等。

2.迭代器:使用迭代器来遍历容器中的元素,如使用vector::iteratorlist::iterator等。

3.算法:使用STL算法来处理容器中的数据,如sortfindcopy等。

4.函数对象:使用函数对象来实现自定义的算法逻辑,如greater<int>()less<int>()等。

经典C++例题:

题目:使用STL容器和算法对一组整数进行排序和去重。

示例代码

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::vector<int> vec = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};// 对vector中的元素进行排序std::sort(vec.begin(), vec.end());// 使用unique算法去除重复元素auto last = std::unique(vec.begin(), vec.end());// 删除重复元素后的尾部vec.erase(last, vec.end());// 使用迭代器遍历排序后的vectorfor (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) {std::cout << *it << " ";}std::cout << std::endl;return 0;
}

例题分析

1.排序:使用std::sort算法对vector中的元素进行排序。sort函数接受两个迭代器参数,分别指向要排序的范围的开始和结束。

2.去重:使用std::unique算法去除vector中的重复元素。unique函数将重复的元素移动到vector的末尾,并返回一个指向新的无重复元素范围末尾的迭代器。

3.删除重复元素:使用vectorerase成员函数删除unique算法处理后vector末尾的重复元素。

4.使用迭代器遍历:创建一个std::vector<int>::iterator类型的迭代器it,并将其初始化为指向vector的开始位置。在for循环中,使用迭代器it来访问vector中的每个元素。

5.输出结果:在for循环中,使用*it来解引用迭代器,获取当前指向的元素,并将其打印出来。

        这个例题展示了如何在C++中使用STL容器和算法来对一组整数进行排序和去重,并使用迭代器来遍历排序后的vector。通过这个例子,可以更好地理解STL在处理数据集合和算法操作中的应用,以及如何使用STL来高效地解决问题。STL提供了一套丰富的组件,使得数据结构和算法的实现变得简单和直观。

Vector

vector是C++标准模板库(STL)中的一个动态数组容器,它能够存储任意类型的元素,并且能够根据需要自动调整其大小。vector提供了快速的随机访问能力,可以通过索引直接访问元素,同时也支持在尾部添加和删除元素的高效操作。

vector的特点:

1.动态数组vector类似于动态数组,可以在运行时增加或减少其大小。

2.快速访问vector提供了与数组相同的快速随机访问能力,可以通过索引直接访问元素。

3.尾部操作高效:在vector的尾部添加和删除元素是非常高效的,因为这些操作不需要移动现有元素。

4.中间和头部操作低效:在vector的中间或头部进行插入和删除操作通常需要移动大量的元素,因此效率较低。

5.自动内存管理vector在超出作用域时会自动释放其占用的内存。

常见用法:

1.存储动态集合:当需要存储一个大小可变的集合时,可以使用vector

2.快速随机访问:当需要快速访问集合中的元素时,可以使用vector

3.尾部操作:当需要频繁在集合的尾部添加或删除元素时,可以使用vector

4.排序和搜索:当需要对集合进行排序或搜索时,可以使用vector,并结合STL算法如sortbinary_search

经典C++例题:

题目:使用vector存储一系列整数,并使用STL算法对其进行排序和去重。

示例代码

#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>int main() {std::vector<int> vec = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};// 对vector中的元素进行排序std::sort(vec.begin(), vec.end());// 使用unique算法去除重复元素auto last = std::unique(vec.begin(), vec.end());// 删除重复元素后的尾部vec.erase(last, vec.end());// 使用迭代器遍历排序后的vectorfor (std::vector<int>::iterator it = vec.begin(); it != vec.end(); ++it) {std::cout << *it << " ";}std::cout << std::endl;return 0;
}

例题分析

1.排序:使用std::sort算法对vector中的元素进行排序。sort函数接受两个迭代器参数,分别指向要排序的范围的开始和结束。

2.去重:使用std::unique算法去除vector中的重复元素。unique函数将重复的元素移动到vector的末尾,并返回一个指向新的无重复元素范围末尾的迭代器。

3.删除重复元素:使用vectorerase成员函数删除unique算法处理后vector末尾的重复元素。

4.输出结果:使用范围for循环遍历并输出排序和去重后的vector中的元素。

这个例题展示了如何在C++中使用vector和STL算法来对一组整数进行排序和去重。通过这个例子,可以更好地理解vector在处理动态数组和算法操作中的应用,以及如何使用vector和STL算法来高效地解决问题。vector提供了一种灵活且高效的方式来存储和操作动态集合。

set是C++标准模板库(STL)中的一个容器,它存储的元素是唯一的,并且是有序的。set内部通常使用红黑树实现,因此它提供了对数时间复杂度的插入、删除和查找操作。由于set中的元素是唯一的,所以它不支持直接通过索引访问元素,因为没有索引的概念。

Set

set的特点:

1.唯一性set中的元素是唯一的,不允许重复的元素存在。

2.有序性set中的元素是有序的,可以按照升序或降序排列。

3.自动排序:当插入元素时,set会自动将元素按照特定的顺序排列。

4.快速查找:由于元素是有序的,set提供了快速的查找操作。

5.不支持随机访问:由于set是基于红黑树实现的,它不支持通过索引快速访问元素。

常见用法:

1.存储唯一元素集合:当需要存储一组唯一的元素时,可以使用set

2.排序集合:当需要一个有序的集合时,可以使用set

3.快速查找:当需要快速查找集合中的元素时,可以使用set

4.去重:当需要去除重复元素时,可以使用set

经典C++例题:

题目:使用set存储一系列整数,并使用STL算法对其进行排序和去重。

示例代码

#include <iostream>
#include <set>
#include <algorithm>
#include <iterator>int main() {std::set<int> myset = {3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5};// 使用迭代器遍历setfor (std::set<int>::iterator it = myset.begin(); it != myset.end(); ++it) {std::cout << *it << " ";}std::cout << std::endl;return 0;
}

例题分析

1.创建set:使用std::set<int>创建一个整数类型的set,并初始化为包含一系列整数。

2.遍历set:使用范围for循环遍历set中的所有元素。由于set是有序的,元素将按照升序排列。

3.输出结果:在循环中,使用*it来解引用迭代器,获取当前指向的元素,并将其打印出来。

这个例题展示了如何在C++中使用set来存储和管理唯一元素集合,并使用迭代器来遍历set中的元素。通过这个例子,可以更好地理解set在处理唯一元素集合和有序集合中的应用,以及如何使用set来高效地解决问题。set提供了一种简单且高效的方式来存储和操作唯一元素集合。

相关文章:

STL、Vector和Set的讲解和例题分析

STL STL&#xff08;Standard Template Library&#xff0c;标准模板库&#xff09;是C标准库的一部分&#xff0c;它提供了一系列通用的编程组件&#xff0c;包括容器、迭代器、算法和函数对象等。STL是C中实现泛型编程的核心&#xff0c;它允许程序员使用模板编写与数…...

Android 13 aosp hiddenapi config

Android 11 hiddenapi路径 frameworks/base/config/hiddenapi-greylist-packages.txtAndroid 13 hiddenapi路径 frameworks/base/boot/hiddenapi/hiddenapi-unsupported-packages.txt...

数据仓库面试总结

文章目录 1.什么是数据仓库&#xff1f;2.ETL是什么&#xff1f;3.数据仓库和数据库的区别&#xff08;OLTP和OLAP的区别&#xff09;4.数据仓库和数据集市的区别5.维度分析5.1 什么是维度&#xff1f;5.2什么是指标&#xff1f; 6.什么是数仓建模&#xff1f;7.事实表7.维度表…...

git Failed to connect to 你的网址 port 8282: Timed out

git Failed to connect to 你的网址 port 8282: Timed out 出现这个问题的原因是&#xff1a;原来的仓库换了网址&#xff0c;原版网址不可用了。 解决方法如下&#xff1a; 方法一&#xff1a;查看git用户配置是否有如下配置 http.proxyhttp://xxx https.proxyhttp://xxx如果…...

[C++][算法基础]堆排序(堆)

输入一个长度为 n 的整数数列&#xff0c;从小到大输出前 m 小的数。 输入格式 第一行包含整数 n 和 m。 第二行包含 n 个整数&#xff0c;表示整数数列。 输出格式 共一行&#xff0c;包含 m 个整数&#xff0c;表示整数数列中前 m 小的数。 数据范围 1≤m≤n≤&#x…...

备考ICA----Istio实验15---开启 mTLS 自动双向认证实验

备考ICA----Istio实验15—开启mTLS自动双向认证实验 在某些生成环境下,我们希望微服务和微服务之间使用加密通讯方式来确保不被中间人代理. 默认情况下Istio 使用 PERMISSIVE模式配置目标工作负载,PERMISSIVE模式时,服务可以使用明文通讯.为了只允许双向 TLS 流量&#xff0c;…...

Hive SchemaTool 命令详解

Hive schematool 是 hive 自带的管理 schema 的相关工具。 列出详细说明 schematool -help直接输入 schematool 或者schematool -help 输出结果如下&#xff1a; usage: schemaTool-alterCatalog <arg> Alter a catalog, requires--catalogLocation an…...

51单片机入门_江协科技_17~18_OB记录的笔记

17. 定时器 17.1. 定时器介绍&#xff1a;51单片机的定时器属于单片机的内部资源&#xff0c;其电路的连接和运转均在单片机内部完成&#xff0c;无需占用CPU外围IO接口&#xff1b; 定时器作用&#xff1a; &#xff08;1&#xff09;用于计时系统&#xff0c;可实现软件计时&…...

xss.pwnfunction-Ah That‘s Hawt

<svg/onloadalert%26%2340%3B1%26%2341%3B> <svg/>是一个自闭合形式 &#xff0c;当页面或元素加载完成时&#xff0c;onload 事件会被触发&#xff0c;从而可以执行相应的 JavaScript 函数...

Python学习从0开始——005数据结构

Python学习从0开始——005数据结构 一、列表list二、元组和序列三、集合四、字典五、循环技巧六、条件控制七、序列和其它类型的比较 一、列表list 不是所有数据都可以排序或比较。例如&#xff0c;[None, ‘hello’, 10] 就不可排序&#xff0c;因为整数不能与字符串对比&…...

力扣每日一题:LCR112--矩阵中的最长递增路径

题目 给定一个 m x n 整数矩阵 matrix &#xff0c;找出其中 最长递增路径 的长度。 对于每个单元格&#xff0c;你可以往上&#xff0c;下&#xff0c;左&#xff0c;右四个方向移动。 不能 在 对角线 方向上移动或移动到 边界外&#xff08;即不允许环绕&#xff09;。 示例…...

树莓派部署yolov5实现目标检测(ubuntu22.04.3)

最近两天搞了一下树莓派部署yolov5&#xff0c;有点难搞&#xff08;这个东西有点老&#xff0c;版本冲突有些包废弃了等等&#xff09; 最后换到ubuntu系统弄了&#xff0c;下面是我的整体步骤&#xff08;建议先使能一下ssh&#xff08;最下面有&#xff09;&#xff0c;结合…...

2024 年最新使用 Wechaty 开源框架搭建部署微信机器人(微信群智能客服案例)

读取联系人信息 获取当前机器人账号全部联系人信息 bot.on(ready, async () > {console.log("机器人准备完毕&#xff01;&#xff01;&#xff01;")let contactList await bot.Contact.findAll()for (let index 0; index < contactList.length; index) {…...

Redis从入门到精通(九)Redis实战(六)基于Redis队列实现异步秒杀下单

↑↑↑请在文章开头处下载测试项目源代码↑↑↑ 文章目录 前言4.5 分布式锁-Redisson4.5.4 Redission锁重试4.5.5 WatchDog机制4.5.5 MutiLock原理 4.6 秒杀优化4.6.1 优化方案4.6.2 完成秒杀优化 4.7 Redis消息队列4.7.1 基于List实现消息队列4.7.2 基于PubSub的消息队列4.7.…...

什么是多路复用器滤波器

本章将更深入地介绍多路复用器滤波器&#xff0c;以及它们如何用于各种应用中。您将了解到多路复用器如何帮助设计人员创造出更复杂的无线产品。 了解多路复用器 多路复用器是一组射频(RF)滤波器&#xff0c;它们组合在一起&#xff0c;但不会彼此加载&#xff0c;可以在输出之…...

Severt和tomcat的使用(补充)

打包程序 在pom.xml中添加上述代码之后打包时会生成war包并且包的名称是test 默认情况打的是jar包.jar里量但是tomcat要求的是war包. war包Tomcat专属的压缩包. war里面不光有.class还有一些tomcat要求的配置文件(web.xml等)还有前端的一些代码(html, css, js) 点击其右边的m…...

JavaEE初阶——多线程(一)

T04BF &#x1f44b;专栏: 算法|JAVA|MySQL|C语言 &#x1faf5; 小比特 大梦想 此篇文章与大家分享多线程的第一部分:引入线程以及创建多线程的几种方式 此文章是建立在前一篇文章进程的基础上的 如果有不足的或者错误的请您指出! 1.认识线程 我们知道现代的cpu大多都是多核心…...

MongoDB主从复制模式基于银河麒麟V10系统

MongoDB主从复制模式基于银河麒麟V10系统 背景介绍 MongoDB自4.0版本开始已经不再建议使用传统的master/slave复制架构,而是全面采用了复制集(Replica Sets)作为标准的复制和高可用性解决方案。 复制集是MongoDB的一种数据复制和高可用性机制,通过异步同步数据至多个服务…...

Vue使用高德地图

1.在高德平台注册账号 2.我的 > 管理管理中添加Key 3.安装依赖 npm i amap/amap-jsapi-loader --save 或 yarn add amap/amap-jsapi-loader --save 4.导入 AMapLoade import AMapLoader from amap/amap-jsapi-loader; 5.直接上代码&#xff0c;做好了注释&#xff08;初始化…...

2024-04-07(复盘前端)

---HTML 1.HTMl骨架 html&#xff1a;整个网页 head&#xff1a;网页头部&#xff0c;用来存放给浏览器看的信息&#xff0c;如css body&#xff1a;网页主体&#xff0c;用来存放给用户看的信息&#xff0c;例如图片和文字 2.标题标签中h1标签只能使用一次&#xff0c;其…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

Prompt Tuning、P-Tuning、Prefix Tuning的区别

一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...

抖音增长新引擎:品融电商,一站式全案代运营领跑者

抖音增长新引擎&#xff1a;品融电商&#xff0c;一站式全案代运营领跑者 在抖音这个日活超7亿的流量汪洋中&#xff0c;品牌如何破浪前行&#xff1f;自建团队成本高、效果难控&#xff1b;碎片化运营又难成合力——这正是许多企业面临的增长困局。品融电商以「抖音全案代运营…...

Cloudflare 从 Nginx 到 Pingora:性能、效率与安全的全面升级

在互联网的快速发展中&#xff0c;高性能、高效率和高安全性的网络服务成为了各大互联网基础设施提供商的核心追求。Cloudflare 作为全球领先的互联网安全和基础设施公司&#xff0c;近期做出了一个重大技术决策&#xff1a;弃用长期使用的 Nginx&#xff0c;转而采用其内部开发…...

今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存

文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

浪潮交换机配置track检测实现高速公路收费网络主备切换NQA

浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求&#xff0c;本次涉及的主要是收费汇聚交换机的配置&#xff0c;浪潮网络设备在高速项目很少&#xff0c;通…...

PHP 8.5 即将发布:管道操作符、强力调试

前不久&#xff0c;PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5&#xff01;作为 PHP 语言的又一次重要迭代&#xff0c;PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是&#xff0c;借助强大的本地开发环境 ServBay&am…...

Kubernetes 节点自动伸缩(Cluster Autoscaler)原理与实践

在 Kubernetes 集群中&#xff0c;如何在保障应用高可用的同时有效地管理资源&#xff0c;一直是运维人员和开发者关注的重点。随着微服务架构的普及&#xff0c;集群内各个服务的负载波动日趋明显&#xff0c;传统的手动扩缩容方式已无法满足实时性和弹性需求。 Cluster Auto…...

DeepSeek越强,Kimi越慌?

被DeepSeek吊打的Kimi&#xff0c;还有多少人在用&#xff1f; 去年&#xff0c;月之暗面创始人杨植麟别提有多风光了。90后清华学霸&#xff0c;国产大模型六小虎之一&#xff0c;手握十几亿美金的融资。旗下的AI助手Kimi烧钱如流水&#xff0c;单月光是投流就花费2个亿。 疯…...

js 设置3秒后执行

如何在JavaScript中延迟3秒执行操作 在JavaScript中&#xff0c;要设置一个操作在指定延迟后&#xff08;例如3秒&#xff09;执行&#xff0c;可以使用 setTimeout 函数。setTimeout 是JavaScript的核心计时器方法&#xff0c;它接受两个参数&#xff1a; 要执行的函数&…...