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

C++ 常见容器获取头元素的方法全览

在C++编程中,容器是存储和管理数据集合的重要工具。不同的容器提供了不同的接口来访问和操作其中的元素。获取容器的头元素(即第一个元素)是常见的操作之一。本文将详细列举C++标准库中所有常见容器获取头元素的方法,并对每种方法进行简要说明。

一、std::vector

std::vector是一个动态数组,它允许快速随机访问元素。要获取std::vector的头元素,可以使用索引或迭代器。

通过索引访问

std::vector<int> vec = {1, 2, 3, 4, 5};
int head = vec[0]; // 获取头元素,即第一个元素

通过迭代器访问

std::vector<int> vec = {1, 2, 3, 4, 5};
int head = *vec.begin(); // 获取头元素,begin() 返回指向第一个元素的迭代器
二、std::list

std::list是一个双向链表,它允许在容器的任意位置进行高效的插入和删除操作。要获取std::list的头元素,只能使用迭代器。

通过迭代器访问

std::list<int> lst = {1, 2, 3, 4, 5};
int head = *lst.begin(); // 获取头元素,begin() 返回指向第一个元素的迭代器

std::list不支持通过索引访问元素,因为链表的内存布局不是连续的。

三、std::deque

std::deque是一个双端队列,它允许在容器的两端进行高效的插入和删除操作。与std::vector类似,std::deque也支持通过索引和迭代器访问元素。

通过索引访问(仅在支持随机访问的编译器实现中可用,但标准并未强制要求):

std::deque<int> deq = {1, 2, 3, 4, 5};
int head = deq[0]; // 获取头元素,注意这并非标准强制的行为

通过迭代器访问(推荐方式):

std::deque<int> deq = {1, 2, 3, 4, 5};
int head = *deq.begin(); // 获取头元素,begin() 返回指向第一个元素的迭代器
四、std::forward_list

std::forward_list是一个单向链表,它只允许单向遍历。要获取std::forward_list的头元素,同样只能使用迭代器。

通过迭代器访问

std::forward_list<int> flst = {1, 2, 3, 4, 5};
int head = *flst.before_begin().next(); // 获取头元素,before_begin() 返回指向第一个元素之前的迭代器,然后调用 next()

注意,std::forward_list的迭代器是单向的,且不支持--操作符,因此访问头元素稍微有些特殊。

五、std::setstd::multiset

std::setstd::multiset是基于红黑树的有序集合。它们不允许重复元素(multiset允许重复键但值仍需唯一)。要获取这些容器的头元素,可以使用迭代器。

通过迭代器访问

std::set<int> s = {1, 2, 3, 4, 5};
int head = *s.begin(); // 获取头元素,即最小的元素

对于std::multiset,操作是相同的。

六、std::mapstd::multimap

std::mapstd::multimap是基于红黑树的关联容器,它们存储键值对。要获取这些容器的头元素的键或值,可以使用迭代器。

通过迭代器访问键

std::map<int, std::string> m = {{1, "one"}, {2, "two"}, {3, "three"}};
int head_key = m.begin()->first; // 获取头元素的键

通过迭代器访问值

std::string head_value = m.begin()->second; // 获取头元素的值

对于std::multimap,操作是相同的,但请注意,由于multimap允许重复键,因此头元素可能不是唯一的。

七、std::unordered_setstd::unordered_multiset

std::unordered_setstd::unordered_multiset是基于哈希表的无序集合。它们同样不允许重复元素(unordered_multiset允许重复元素)。要获取这些容器的头元素,可以使用迭代器。

通过迭代器访问

std::unordered_set<int> us = {1, 2, 3, 4, 5};
int head = *us.begin(); // 获取头元素,但不一定是插入顺序的第一个元素

对于std::unordered_multiset,操作是相同的。

八、std::unordered_mapstd::unordered_multimap

std::unordered_mapstd::unordered_multimap是基于哈希表的无序关联容器。它们存储键值对。要获取这些容器的头元素的键或值,可以使用迭代器。

通过迭代器访问键

std::unordered_map<int, std::string> um = {{1, "one"}, {2, "two"}, {3, "three"}};
int head_key = um.begin()->first; // 获取头元素的键

通过迭代器访问值

std::string head_value = um.begin()->second; // 获取头元素的值

对于std::unordered_multimap,操作是相同的,但同样请注意,由于unordered_multimap允许重复键,因此头元素可能不是唯一的。

九、std::stack

std::stack是一个适配器,它基于其他容器(如std::dequestd::vector)实现栈的功能。要获取std::stack的头元素(即栈顶元素),可以使用top()方法。

通过top()方法访问

std::stack<int> stk = {1, 2, 3, 4, 5};
int head = stk.top(); // 获取头元素,即栈顶元素
十、std::queue

std::queue也是一个适配器,它基于其他容器(如std::deque)实现队列的功能。要获取std::queue的头元素(即队首元素),可以使用front()方法。

通过front()方法访问

std::queue<int> q = {1, 2, 3, 4, 5};
int head = q.front(); // 获取头元素,即队首元素

std::queue没有top()方法,这是std::stack特有的。

十一、std::priority_queue

std::priority_queue是一个适配器,它基于其他容器(如std::vector)实现优先队列的功能。要获取std::priority_queue的头元素(即具有最高优先级的元素),可以使用top()方法。

通过top()方法访问

std::priority_queue<int> pq = {1, 2, 3, 4, 5};
int head = pq.top(); // 获取头元素,即具有最高优先级的元素
总结

在C++标准库中,不同的容器提供了不同的接口来访问它们的头元素。对于序列容器(如std::vectorstd::liststd::deque等),通常使用索引或迭代器来访问头元素。对于关联容器(如std::setstd::map等)和无序关联容器(如std::unordered_setstd::unordered_map等),则使用迭代器来访问头元素。对于栈(std::stack)和优先队列(std::priority_queue),使用top()方法来获取头元素。而对于队列(std::queue),则使用front()方法来获取头元素。

了解这些容器如何访问头元素是掌握C++标准库的重要一步,它将帮助你更有效地编写和调试C++程序。

相关文章:

C++ 常见容器获取头元素的方法全览

在C编程中&#xff0c;容器是存储和管理数据集合的重要工具。不同的容器提供了不同的接口来访问和操作其中的元素。获取容器的头元素&#xff08;即第一个元素&#xff09;是常见的操作之一。本文将详细列举C标准库中所有常见容器获取头元素的方法&#xff0c;并对每种方法进行…...

Java putIfAbsent() 详解

Java putIfAbsent() 方法详解 在 Java 中&#xff0c;putIfAbsent() 是 Map 接口中的一个方法&#xff0c;从 Java 8 开始引入。它用于向映射中添加一个键值对&#xff0c;只有在该键尚未存在时才进行添加操作。如果键已存在&#xff0c;则不会覆盖原有值。 1. 方法定义 方法…...

使用PSpice进行第一个电路的仿真

1、单击【开始】菜单&#xff0c;选择【OrCAD Capture CIS Lite】。 2、单击【File】>【New】>【Project】。 3、①填入Name下面的文本框&#xff08;提示&#xff1a;项目名称不要出现汉字&#xff09;&#xff1b; ②选择【Analog or Mixed A/D】&#xff1b; ③单击【…...

路漫漫其修远兮,吾将上下而求索---第一次使用github的过程记录和个人感受

文章目录 1.仓库位置2.新建仓库3.配置仓库4.克隆和上传5.推荐文章和我的感受 1.仓库位置 这个仓库的位置就是在我们的这个个人主页的右上角&#xff1b;如果是第一次注册账号的话&#xff0c;这个主页里面肯定是不存在仓库的&#xff0c;需要我们自己手动的进行创建&#xff1…...

【微软:多模态基础模型】(4)统一视觉模型

欢迎关注[【youcans的AGI学习笔记】](https://blog.csdn.net/youcans/category_12244543.html&#xff09;原创作品 【微软&#xff1a;多模态基础模型】&#xff08;1&#xff09;从专家到通用助手 【微软&#xff1a;多模态基础模型】&#xff08;2&#xff09;视觉理解 【微…...

GRS码(Generalized Reed-Solomon Code)

定义&#xff1a; 令 k ≤ n ≤ q k\le n\le q k≤n≤q&#xff0c; α ∈ F q n \alpha\in\mathbb{F}_q^n α∈Fqn​是n元组&#xff08; α ( α 1 , . . . , α n ) , α i ≠ α j , ∀ i ≠ j ∈ { 1 , . . . , n } \alpha(\alpha_1,...,\alpha_n),\alpha_i\ne \alpha_j,…...

三、谷粒商城- Spring Cloud Alibaba(3)

&#x1f33b;&#x1f33b; 目录 &#x1f33b;&#x1f33b; 一、SpringCloud Alibaba1.1、SpringCloud Alibaba 简介1.2、SpringCloud Alibaba-Nacos[作为注册中心]1.2.1 将微服务注册到 nacos 中1.2.2 服务注册到 nacos&#xff0c;远程调用 1.3、SpringCloud Alibaba-Naco…...

MATLAB和Python激发光谱

激发光谱是一种用于研究物质发光特性的分析方法。当样品吸收特定波长的光时&#xff0c;电子从基态跃迁至激发态。随后&#xff0c;当电子返回基态时&#xff0c;会发射出光子&#xff0c;产生荧光或磷光。激发光谱通过测量不同波长的入射光激发下的发光强度来获取数据。该技术…...

学习笔记024——Ubuntu 安装 Redis遇到相关问题

目录 1、更新APT存储库缓存&#xff1a; 2、apt安装Redis&#xff1a; 3、如何查看检查 Redis版本&#xff1a; 4、配置文件相关设置&#xff1a; 5、重启服务&#xff0c;配置生效&#xff1a; 6、查看服务状态&#xff1a; 1、更新APT存储库缓存&#xff1a; sudo apt…...

UE5 腿部IK 解决方案 footplacement

UE5系列文章目录 文章目录 UE5系列文章目录前言一、FootPlacement 是什么&#xff1f;二、具体实现 前言 在Unreal Engine 5 (UE5) 中&#xff0c;腿部IK&#xff08;Inverse Kinematics&#xff0c;逆向运动学&#xff09;是一个重要的动画技术&#xff0c;用于实现角色脚部准…...

北航软件算法C4--图部分

C4上级图部分 TOPO!步骤代码段TOPO排序部分 完整代码 简单的图图题目描述输入输出样例步骤代码段开辟vector容器作为dist二维数组初始化调用Floyd算法查询 完整代码 负环题目描述输入输出样例步骤代码段全局变量定义spfa1函数用于判断是否有负环spfa2用于记录每个点到1号点的距…...

PCL点云开发-解决在Qt中嵌入点云窗口出现的一闪而过的黑窗口

PCL点云开发-解决在Qt中嵌入点云窗口出现的一闪而过的黑窗口 众所周知&#xff0c;在windows下开发PCL点云最快的方式就是到官网下载其预编译好的库&#xff0c;比如&#xff1a; PCL-1.14.0-AllInOne-msvc2022-win64.exe 这时候你到网络上搜索&#xff0c;大概率会有两种方案…...

本地音乐服务器(二)

4. 上传音乐模块设计 4.1 上传音乐的接口设计 请求和响应设计&#xff1a; 新建music实体类&#xff1a; Data public class Music {private int id;private String title;private String singer;private String time;private String url;private int userid; } 4.2 创建Mu…...

第三十六篇——伯努利试验:到底如何理解随机性?

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 概率论指导着我们对于直觉不靠谱的事情&#xff0c;以及为我们如何更高效…...

【Android、IOS、Flutter、鸿蒙、ReactNative 】屏幕适配

Android Java 屏幕适配 参考 今日头条适配依赖配置 添加设计屏幕尺寸 设置字体大小 通过切换不同屏幕尺寸查看字体大小 设置文本宽高 通过切换不同屏幕尺寸查看文本宽高 Android Compose 屏幕适配 <...

candence : 如何利用EXCEL 绘制复杂、多管脚元件

如何利用EXCEL 绘制复杂、多管脚元件 前面的步骤直接略过 我们以STM32F407VEXX 系列 100pin 芯片为例讲解&#xff1a; 1、新建好一个空元件 2、使用阵列&#xff0c;放置管脚 点击 “ ok ” 3、选中所有管脚 右键 “edit properites” 出现如下页面 4、点击 左上角&…...

项目配置文件选择(Json,xml,Yaml, INI)

选择使用哪种类型的配置文件&#xff08;如 JSON、XML 或其他格式&#xff09;取决于多个因素&#xff0c;包括项目的需求、团队的熟悉程度、数据结构的复杂性以及可读性和可维护性等。以下是对常见配置文件格式的比较&#xff0c;以及在不同情况下的推荐&#xff1a; 1. JSON&…...

Android 使用Retrofit 以纯二进制文件流上传文件

一、背景 一般上传文件都是以表单形式上传文件&#xff0c;最近项目中涉及到非表单形式上传文件流&#xff0c;分为单个文件流上传、大文件分段上传&#xff0c;此种情景资料较少&#xff0c;这里记录下。 二、方案介绍 2.1 需求协议 1. 上传文件 API 端点&#xff1a;/serv…...

Vue3踩坑记录

目录 一、定义常变量 1.1、ref和reactive到底用谁&#xff1f; 二、双向绑定 2.1、直接改变表格该行数据 2.1、在弹窗改变表格该行数据 一、定义常变量 1.1、ref和reactive到底用谁&#xff1f; 已知&#xff1a;使用ref定义基础类型数据&#xff1b;使用reactive定义复…...

大数据-227 离线数仓 - Flume 自定义拦截器(续接上节) 采集启动日志和事件日志

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇开始了&#xff01; 目前开始更新 MyBatis&#xff0c;一起深入浅出&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff0…...

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…...

python爬虫:Newspaper3k 的详细使用(好用的新闻网站文章抓取和解析的Python库)

更多内容请见: 爬虫和逆向教程-专栏介绍和目录 文章目录 一、Newspaper3k 概述1.1 Newspaper3k 介绍1.2 主要功能1.3 典型应用场景1.4 安装二、基本用法2.2 提取单篇文章的内容2.2 处理多篇文档三、高级选项3.1 自定义配置3.2 分析文章情感四、实战案例4.1 构建新闻摘要聚合器…...

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

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

全志A40i android7.1 调试信息打印串口由uart0改为uart3

一&#xff0c;概述 1. 目的 将调试信息打印串口由uart0改为uart3。 2. 版本信息 Uboot版本&#xff1a;2014.07&#xff1b; Kernel版本&#xff1a;Linux-3.10&#xff1b; 二&#xff0c;Uboot 1. sys_config.fex改动 使能uart3(TX:PH00 RX:PH01)&#xff0c;并让boo…...

智能分布式爬虫的数据处理流水线优化:基于深度强化学习的数据质量控制

在数字化浪潮席卷全球的今天&#xff0c;数据已成为企业和研究机构的核心资产。智能分布式爬虫作为高效的数据采集工具&#xff0c;在大规模数据获取中发挥着关键作用。然而&#xff0c;传统的数据处理流水线在面对复杂多变的网络环境和海量异构数据时&#xff0c;常出现数据质…...

苹果AI眼镜:从“工具”到“社交姿态”的范式革命——重新定义AI交互入口的未来机会

在2025年的AI硬件浪潮中,苹果AI眼镜(Apple Glasses)正在引发一场关于“人机交互形态”的深度思考。它并非简单地替代AirPods或Apple Watch,而是开辟了一个全新的、日常可接受的AI入口。其核心价值不在于功能的堆叠,而在于如何通过形态设计打破社交壁垒,成为用户“全天佩戴…...

Vue3中的computer和watch

computed的写法 在页面中 <div>{{ calcNumber }}</div>script中 写法1 常用 import { computed, ref } from vue; let price ref(100);const priceAdd () > { //函数方法 price 1price.value ; }//计算属性 let calcNumber computed(() > {return ${p…...

uni-app学习笔记三十五--扩展组件的安装和使用

由于内置组件不能满足日常开发需要&#xff0c;uniapp官方也提供了众多的扩展组件供我们使用。由于不是内置组件&#xff0c;需要安装才能使用。 一、安装扩展插件 安装方法&#xff1a; 1.访问uniapp官方文档组件部分&#xff1a;组件使用的入门教程 | uni-app官网 点击左侧…...

[特殊字符] 手撸 Redis 互斥锁那些坑

&#x1f4d6; 手撸 Redis 互斥锁那些坑 最近搞业务遇到高并发下同一个 key 的互斥操作&#xff0c;想实现分布式环境下的互斥锁。于是私下顺手手撸了个基于 Redis 的简单互斥锁&#xff0c;也顺便跟 Redisson 的 RLock 机制对比了下&#xff0c;记录一波&#xff0c;别踩我踩过…...

Linux-进程间的通信

1、IPC&#xff1a; Inter Process Communication&#xff08;进程间通信&#xff09;&#xff1a; 由于每个进程在操作系统中有独立的地址空间&#xff0c;它们不能像线程那样直接访问彼此的内存&#xff0c;所以必须通过某种方式进行通信。 常见的 IPC 方式包括&#…...