C语言怎么创建和使用哈希表
时间: 2023-10-24 09:18:43 浏览: 106
C语言中可以通过结构体和指针来创建和使用哈希表。
首先,需要定义一个哈希表结构体,包括哈希表大小、哈希函数、桶数组等属性。例如:
```
#define HASH_SIZE 1000 // 哈希表大小
// 哈希表节点结构体
typedef struct hash_node {
int key;
int value;
struct hash_node* next;
} HashNode;
// 哈希表结构体
typedef struct hash_table {
int size;
HashNode** buckets;
unsigned int (*hash_func)(int);
} HashTable;
```
其中,哈希表节点结构体包括键值对和指向下一个节点的指针,哈希表结构体包括哈希表大小、桶数组和哈希函数指针。
接下来,需要实现哈希函数。哈希函数的作用是将键转换成哈希值,并将哈希值映射到桶数组的某个位置。常见的哈希函数有取余法、乘法哈希法等。例如,以下是一个简单的取余法哈希函数:
```
unsigned int hash(int key) {
return key % HASH_SIZE;
}
```
然后,需要实现哈希表的各种操作,包括插入、查找、删除等。这些操作涉及到对桶数组的操作,需要根据哈希值找到对应的桶,并对桶中的节点进行操作。例如,以下是一个插入操作的实现:
```
void hash_table_put(HashTable* table, int key, int value) {
unsigned int hash_value = table->hash_func(key);
HashNode* node = table->buckets[hash_value];
// 遍历桶中的节点,查找是否已存在该键
while (node != NULL) {
if (node->key == key) {
node->value = value;
return;
}
node = node->next;
}
// 如果不存在该键,则新建一个节点插入到桶中
HashNode* new_node = (HashNode*)malloc(sizeof(HashNode));
new_node->key = key;
new_node->value = value;
new_node->next = table->buckets[hash_value];
table->buckets[hash_value] = new_node;
}
```
最后,可以使用哈希表来解决一些问题,例如统计字符串中每个字符出现的次数:
```
void count_chars(char* str) {
HashTable table;
table.size = HASH_SIZE;
table.buckets = (HashNode**)malloc(HASH_SIZE * sizeof(HashNode*));
memset(table.buckets, 0, HASH_SIZE * sizeof(HashNode*));
table.hash_func = hash;
// 遍历字符串中的字符,统计每个字符出现的次数
for (int i = 0; str[i] != '\0'; i++) {
int key = (int)str[i];
HashNode* node = table.buckets[hash(key)];
while (node != NULL) {
if (node->key == key) {
node->value++;
break;
}
node = node->next;
}
if (node == NULL) {
hash_table_put(&table, key, 1);
}
}
// 输出结果
for (int i = 0; i < HASH_SIZE; i++) {
HashNode* node = table.buckets[i];
while (node != NULL) {
printf("%c: %d\n", (char)node->key, node->value);
node = node->next;
}
}
}
```
以上是一个简单的哈希表的实现,实际应用中可能需要考虑哈希冲突、动态扩容等问题。
阅读全文