Rust HashMap详解及单词统计示例

简介: Rust HashMap详解及单词统计示例

在Rust中,HashMap是一种非常有用的数据结构,用于存储键值对。本文将深入介绍HashMap的特性,以及通过一个单词统计的例子展示其用法。

HashMap简介

HashMap是Rust标准库提供的用于存储键值对的数据结构。它允许通过键快速查找对应的值,是一个非常高效的数据结构。以下是一些关键特性:

  • 数据存储在堆上:HashMap的数据存储在堆上,使其具有动态大小,可以根据需要进行扩展或收缩。
  • 同构的:在一个HashMap中,所有的键(K)必须是同一种类型,所有的值(V)也必须是同一种类型。

创建和插入键值对

let mut scores = HashMap::new();
scores.insert(String::from("Blue"), 10);
scores.insert(String::from("Yellow"), 60);

这段代码创建了一个HashMap实例scores,并插入了两个键值对,键为字符串类型,值为整数类型。

使用zipcollect创建HashMap

let teams = vec![String::from("Blue"), String::from("Yellow")];
let initial_scores = vec![10, 50];
let scores: HashMap<_, _> = teams.iter().zip(initial_scores.into_iter()).collect();

在这里,通过zip将两个Vec合并为一个元素为元组的迭代器,然后使用collect方法将迭代器转换为HashMap

HashMap和所有权

HashMap对于实现了Copy trait的类型,如i32,会复制值到HashMap中。对于拥有所有权的值,如String,则会移动值,所有权转移给HashMap

let field_name = String::from("Favorite color");
let field_value = String::from("Blue");

let mut map = HashMap::new();
map.insert(&field_name, &field_value);

在这个例子中,我们插入了field_namefield_value的引用,而不是移动它们。在HashMap有效期内,被引用的值必须保持有效。

访问和遍历HashMap

let team_name = String::from("Blue");
let score = scores1.get(&team_name);
match score {
    None => println!("Team not exist"),
    Some(s) => println!("Score: {}", s),
}

for (k, v) in &scores1 {
    println!("{}: {}", k, v);
}


通过get方法可以根据键获取值,返回一个Option<&V>。通过遍历HashMap,我们可以访问其中的所有键值对。

更新HashMap

let mut scores11 = HashMap::new();
scores11.insert(String::from("Blue"), 10);
scores11.insert(String::from("Blue"), 20);

// 使用entry方法检查键是否存在,不存在时插入新值
scores11.entry(String::from("Yellow")).or_insert(50);
scores11.entry(String::from("Blue")).or_insert(50);

HashMap的大小是可变的,每个键同时只能对应一个值。通过entry方法可以检查键是否存在,不存在时使用or_insert方法插入新值。

单词统计示例

let text = "hello world wonderful world";

let mut map = HashMap::new();
for word in text.split_whitespace() {
    let count = map.entry(word).or_insert(0);
    *count += 1;
}
println!("{:#?}", map);

这段代码展示了如何使用HashMap进行单词统计。通过遍历文本中的单词,使用entry方法检查单词是否存在,不存在时插入新值。最终,得到一个包含每个单词及其出现次数的HashMap

HashMap在Rust中是一个强大的工具,通过合理使用可以简化很多与键值对相关的问题。在实际开发中,我们可以充分利用其特性,提高代码的效率和可读性。

相关文章
|
Rust 算法 安全
【算法学习】1773. 统计匹配检索规则的物品数量(java / c / c++ / python / go / rust)
给你一个数组 items ,其中 items[i] = [typei, colori, namei] ,描述第 i 件物品的类型、颜色以及名称。 另给你一条由两个字符串 ruleKey 和 ruleValue 表示的检索规则。 如果第 i 件物品能满足下述条件之一,则认为该物品与给定的检索规则 匹配 : ruleKey == "type" 且 ruleValue == typei 。 ruleKey == "color" 且 ruleValue == colori 。 ruleKey == "name" 且 ruleValue == namei 。 统计并返回 匹配检索规则的物品数量
【算法学习】1773. 统计匹配检索规则的物品数量(java / c / c++ / python / go / rust)
|
Go
go语言基础数据结构学习 ---- 字典(map)
go语言基础数据结构学习 ---- 字典(map)
159 0
|
存储 缓存 Rust
Rust 笔记:Rust 语言中映射(HashMap)与集合(HashSet)及其用法
本文介绍 Rust 中哈希结构相关概念及其使用。在 Rust 中,提供了两种哈希表,一个是 HashMap,另外一个是 HashSet,本文都将逐一介绍,并介绍 哈希函数 的用法。
374 0
|
10月前
|
安全 Go 开发工具
Go语言学习6-字典类型
【1月更文挑战第7天】本篇 Huazie 介绍 Go语言中的字典类型
81 1
Go语言学习6-字典类型
|
8月前
|
大数据 程序员 Python
Python数据类型大变身!掌握列表推导式与生成器,编程效率翻倍不是梦
【7月更文挑战第2天】在Python中,列表推导式和生成器是提升效率的利器。列表推导式以简洁方式处理循环和条件,如将偶数平方化简为一行代码,提高代码可读性。生成器则按需生成数据,减少内存占用,适合处理大数据。通过`yield`函数实现惰性求值,有效避免内存溢出。掌握这两者,能优化Python编程体验。
55 0
|
Rust 编译器 API
【Rust指南】结合String深入理解Rust语言的Slice(切片)类型
【Rust指南】结合String深入理解Rust语言的Slice(切片)类型
426 0
【Rust指南】结合String深入理解Rust语言的Slice(切片)类型
|
Kotlin
kotlin高阶函数开发一个程序,统计文本中字符串出现的个数
一、高阶函数是Kotlin的核心部分,下面来使用下高阶函数写一个程序 注意:我这里的File使用的是:与src同级的文件,你可以根据自己的需要,修改文件地址 代码实例 package net.
1377 0
|
10月前
|
Rust 索引 Windows
Rust 原始类型之数组array内置方法
Rust 原始类型之数组array内置方法
305 0
Rust 原始类型之数组array内置方法
|
10月前
|
C++
C++语言学习数组和字符串应用案例
【4月更文挑战第8天】该文展示了C++中数组和字符串的应用案例。数组示例定义了一个整数数组并访问、修改其元素,计算了元素之和。字符串示例中,定义了一个字符串并遍历、修改字符,进行了字符串拼接、查找子字符串及替换操作。
64 3