c++ STL库 unordered_map

#include <iostream
#include <string
#include <unordered_map

int main() {
// 创建一个 unordered_map
std::unordered_map<std::string, int> wordCount;

// 插入元素
wordCount["apple"] = 1;
wordCount["banana"] = 2;

// 使用 insert 方法插入键值对
wordCount.insert({ "orange", 3 });

// 访问元素
std::cout << "Count for 'apple': " << wordCount["apple"] << std::endl;

// 检查键是否存在
if (wordCount.find("banana") != wordCount.end()) {
   std::cout << "'banana' is in the map." << std::endl;
}

// 遍历 unordered_map
std::cout << "All elements in unordered_map:" << std::endl;
for (const auto& pair : wordCount) {
   std::cout << pair.first << ": " << pair.second << std::endl;
}

// 修改元素
wordCount["apple"] = 5;

// 删除元素

wordCount.erase(“orange”);

return 0;

}

————————————————————————
代码可以大聪明写,
解释和描述 自己敲一波:

1、auto 让编译器 自己对 pair进行类型推导,可以是int 、char等。避免复杂类型声明。
2、const 是修饰pair,以防遍历过程中 键、值 任何被修改。

3、&表示引用,pair去引用 容器中的元素,避免拷贝。const &,引用形式访问,并且不被修改,速度快。

4、用范围基(range-based) for循环 遍历 map:

for(const auto& pair: &wordCount)
{cout<< pair.first<<pair.second<<endl;
}
first 、 second 分别对应键、值,

范围基 for 循环是 简单的循环语法,遍历容器所有元素。不用显式 使用迭代器或者索引。
用法:
for (declaration : expressin)
statement;

declaration:用于声明一个变量,这个变量将被用于访问容器中的每个元素。在遍历期间,这个变量会逐个绑定到容器中的所有元素。此处为pair。
expression:通常是一个容器或数组,表示要遍历的集合。 此处为wordCount
statement:在循环体中执行的语句,每次迭代都会执行。此处为cout<< pair.first<<pair.second<<endl;

5、pair是 map的 每个迭代器 指向的元素的引用 。即为对 unordered_map 存储的 std::pair<const std:;string,int >对象的引用。
迭代器被用来遍历容器,类似指针,但是自身不暴漏给循环结构。如果非得显式使用 如下 it是迭代器 ->访问键、值:

for(auto it = wordCount.begin(); it !=wordCount.end();++it)
{
std::cout<< it->first<<“:”<sencond<<endl;
}

6、std::unordered_map<std::string, int> wordCount;

尖括号<>  是模板编程核心语法元素。
定义c++ 的模板 或者 实例的类型,告诉编译器 要用 特定类型实例化 模板。

此处定义 wordCount 变量,键类型为string 值类型为int。

7、 visual studio 2022 IDE

直接打开新建 c++ 空项目,项目 源文件上 右键 新建 xx.cpp文件。
运行 结果如下:

Count for ‘apple’: 1
‘banana’ is in the map.
All elements in unordered_map:
apple: 1
banana: 2
orange: 3

C:\Users\hpl\source\repos\heima\x64\Debug\heima.ex (进程 16832)已退出,代码为 0。
按任意键关闭此窗口. . .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值