C++中如何实现和使用哈希表(HashMap/unordered_map)?
时间: 2024-12-02 17:14:53 浏览: 33
在C++中,哈希表(通常称为unordered_map或HashMap)是由`<unordered_map>`模板容器提供的,它使用哈希函数将键快速映射到存储位置。以下是基本的使用步骤:
1. 包含头文件:
```cpp
#include <unordered_map>
```
2. 创建实例:
```cpp
std::unordered_map<std::string, int> myMap; // 键为字符串,值为整数
```
或者指定初始容量和负载因子:
```cpp
std::unordered_map<std::string, int, std::hash<std::string>, std::equal_to<std::string>> myMap(100, 0.75); // 容量100,负载因子0.75
```
3. 插入元素:
```cpp
myMap["apple"] = 5; // "apple" 存储为键,值为5
```
4. 查找元素:
```cpp
int count = myMap["apple"]; // 如果存在则返回对应的值,否则返回默认值(如未初始化则抛异常)
```
5. 删除元素:
```cpp
myMap.erase("apple"); // 移除键为"apple"的项
```
6. 遍历:
```cpp
for (const auto &pair : myMap) {
std::cout << pair.first << ": " << pair.second << '\n';
}
```
相关问题
unordered_map c实现
unordered_map 是 C++ 标准库中的一个容器,用于存储键值对,并支持快速的插入、删除和查找操作。C++ 的 unordered_map 可以通过哈希表来实现。
要在 C 中实现一个类似 unordered_map 的数据结构,你可以使用哈希表和链表的组合。下面是一个简单的示例:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define TABLE_SIZE 100
// 哈希表中的节点
typedef struct Node {
char key[20];
int value;
struct Node* next;
} Node;
// 哈希表
typedef struct HashMap {
Node* table[TABLE_SIZE];
} HashMap;
// 计算哈希值
int hash(const char* key) {
int hash = 0;
while (*key) {
hash += *key;
key++;
}
return hash % TABLE_SIZE;
}
// 初始化哈希表
HashMap* HashMap_Create() {
HashMap* map = (HashMap*)malloc(sizeof(HashMap));
memset(map->table, 0, sizeof(map->table));
return map;
}
// 向哈希表中插入键值对
void HashMap_Insert(HashMap* map, const char* key, int value) {
int index = hash(key);
Node* newNode = (Node*)malloc(sizeof(Node));
strcpy(newNode->key, key);
newNode->value = value;
newNode->next = NULL;
if (map->table[index] == NULL) {
map->table[index] = newNode;
} else {
Node* current = map->table[index];
while (current->next != NULL) {
current = current->next;
}
current->next = newNode;
}
}
// 从哈希表中删除指定键的节点
void HashMap_Remove(HashMap* map, const char* key) {
int index = hash(key);
Node* current = map->table[index];
Node* previous = NULL;
while (current != NULL && strcmp(current->key, key) != 0) {
previous = current;
current = current->next;
}
if (current == NULL) {
return; // 未找到指定键的节点
}
if (previous == NULL) {
map->table[index] = current->next;
} else {
previous->next = current->next;
}
free(current);
}
// 从哈希表中获取指定键对应的值
int HashMap_Get(HashMap* map, const char* key) {
int index = hash(key);
Node* current = map->table[index];
while (current != NULL && strcmp(current->key, key) != 0) {
current = current->next;
}
if (current == NULL) {
return -1; // 未找到指定键的节点
}
return current->value;
}
// 销毁哈希表
void HashMap_Destroy(HashMap* map) {
for (int i = 0; i < TABLE_SIZE; i++) {
Node* current = map->table[i];
while (current != NULL) {
Node* next = current->next;
free(current);
current = next;
}
}
free(map);
}
int main() {
HashMap* map = HashMap_Create();
HashMap_Insert(map, "key1", 1);
HashMap_Insert(map, "key2", 2);
HashMap_Insert(map, "key3", 3);
printf("value for key1: %d\n", HashMap_Get(map, "key1"));
printf("value for key2: %d\n", HashMap_Get(map, "key2"));
printf("value for key3: %d\n", HashMap_Get(map, "key3"));
HashMap_Remove(map, "key2");
printf("value for key2: %d\n", HashMap_Get(map, "key2"));
HashMap_Destroy(map);
return 0;
}
```
这个示例演示了如何使用哈希表和链表组合来实现一个类似 unordered_map 的数据结构。你可以根据实际需求进行修改和扩展。
C语言中如何使用unordered_map
在C++标准库中,`unordered_map`是一个关联容器,它实现了哈希表数据结构,允许你在常数时间内查找、插入和删除元素,只要键的哈希函数足够好。在C语言中,通常我们使用`#include <stdlib.h>`中的`malloc`, `free`, 和`hash_map`(在旧版本的C++中),但是这个库在C++11之后已被`std::unordered_map`取代,这是C++的一部分。
如果你想在C++中使用`unordered_map`,首先需要包含头文件:
```cpp
#include <unordered_map>
```
然后创建一个映射实例,例如存储字符串到整数的关系:
```cpp
std::unordered_map<std::string, int> myMap;
```
添加元素:
```cpp
myMap["apple"] = 1;
myMap["banana"] = 2;
```
查找元素:
```cpp
int count = myMap.find("apple")->second; // 如果存在返回值,否则为end()
```
删除元素(如果找到):
```cpp
myMap.erase("banana");
```
注意,C语言的标准库并没有提供直接的`unordered_map`支持,上述示例是在C++中演示的。如果你在C环境中使用,可能需要使用第三方库如jemalloc和jemalloc-hashmap等实现类似的功能。
阅读全文