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

c++字典

在C++中,“字典”通常指的是std::map或std::unordered_map,它们是标准库中提供的关联容器,用于存储键值对。以下是一些常见的操作示例,包括插入、访问、删除和遍历元素。

使用 std::map std::map 是一种有序的关联容器,键值对按键排序。

#include <iostream>
#include <map>int main() {// 创建一个map,键是字符串,值是整数std::map<std::string, int> dictionary;// 插入元素dictionary["apple"] = 1;dictionary["banana"] = 2;dictionary["orange"] = 3;// 访问元素std::cout << "apple: " << dictionary["apple"] << std::endl;// 检查键是否存在if (dictionary.find("banana") != dictionary.end()) {std::cout << "banana exists with value: " << dictionary["banana"] << std::endl;} else {std::cout << "banana does not exist" << std::endl;}// 遍历所有元素for (const auto& pair : dictionary) {std::cout << pair.first << ": " << pair.second << std::endl;}// 删除元素dictionary.erase("orange");// 尝试访问已删除的元素if (dictionary.find("orange") == dictionary.end()) {std::cout << "orange has been deleted" << std::endl;}// 清空mapdictionary.clear();return 0;
}

使用 std::unordered_map std::unordered_map
是一种无序的关联容器,基于哈希表实现,查找、插入和删除操作平均时间复杂度为O(1)。

#include <iostream>
#include <unordered_map>int main() {// 创建一个unordered_map,键是字符串,值是整数std::unordered_map<std::string, int> dictionary;// 插入元素dictionary["apple"] = 1;dictionary["banana"] = 2;dictionary["orange"] = 3;// 访问元素std::cout << "apple: " << dictionary["apple"] << std::endl;// 检查键是否存在if (dictionary.find("banana") != dictionary.end()) {std::cout << "banana exists with value: " << dictionary["banana"] << std::endl;} else {std::cout << "banana does not exist" << std::endl;}// 遍历所有元素for (const auto& pair : dictionary) {std::cout << pair.first << ": " << pair.second << std::endl;}// 删除元素dictionary.erase("orange");// 尝试访问已删除的元素if (dictionary.find("orange") == dictionary.end()) {std::cout << "orange has been deleted" << std::endl;}// 清空unordered_mapdictionary.clear();return 0;
}

总结

std::map:键值对按键排序,适用于需要保持顺序的场景。例如,如果你需要按字母顺序遍历元素。
std::unordered_map:键值对无序,但查找、插入和删除速度更快,适用于不需要顺序的场景。例如,如果你只需要快速查找、插入和删除元素。
两种容器在实际使用中的选择依赖于具体需求,例如是否需要键的有序性和性能要求等。如果需要按键排序,可以使用std::map;如果更关注性能且不需要有序性,可以选择std::unordered_map。

http://www.lryc.cn/news/385940.html

相关文章:

  • rga_mm: RGA_MMU unsupported Memory larger than 4G!解决
  • 构建个人文件上传服务:Python Flask实现上传和下载完整指南
  • 瓦罗兰特新赛季更新资讯 瓦罗兰特新赛季免费加速器
  • 希尔排序的实现
  • 使用Python selenium爬虫领英数据,并进行AI岗位数据挖掘
  • 如何在Android应用程序中实现高效的图片加载和缓存机制。
  • 【机器学习项目实战(二)】基于朴素贝叶斯的中文垃圾短信分类
  • 当用户需求不详细时,如何有效应对
  • 最新AI智能聊天对话问答系统源码(图文搭建部署教程)+AI绘画,文生图,TTS语音识别输入,文档分析
  • [图解]SysML和EA建模住宅安全系统-02-现有运营领域-块定义图
  • 【vuejs】首次页面加载时触发那些声明周期钩子函数
  • adb热更新
  • Nuxt 的路由结构系统(七)
  • 不使用AMap.DistrictSearch,通过poi数据绘制省市县区块
  • vue+webpack子应用嵌入乾坤框架
  • Oracle中常用内置函数
  • 餐饮冷库安全守护神:可燃气体报警器检定的科学性与有效性
  • 中国能源统计年鉴(1986-2023年)
  • 摄像头画面显示于unity场景
  • Double 4 VR智能仿真教学系统在国际邮轮乘务管理专业课堂上的应用
  • QSPI四线SPI:D0、D1、D2、D3
  • vue3通过vue-video-player实现视频倍速、默认全屏、拖拽进度条等功能
  • 微信小程序 点击左上角返回弹窗提示
  • openEuler 22.03 (LTS-SP1)服务器用ntpd同步GPS时间服务器的案例
  • Git的安装以及使用
  • 双路视频同屏显示(拼接)-基于野火Zynq7020开发板
  • ForkJoinPool浅析
  • 【AI-小米机器狗】Dockerfile包含SSH和SFTP
  • 仿真CAN报文发送的CRC校验算法(附CAPL代码)
  • 如何在Android应用中最佳实现“Edge to Edge“特性?