链接法hash表

/*
 *一个通过链接法解决碰撞问题的Hash表
 *主要实现的功能是:
 *1.读取全域数据并通过hash映射保存到hash表中
 *2.查询一个属于全域中的数据在hash表中的位置
 *
 *          Author: StoryMonster
 *Last Change Date: 2016/6/24
 */
#include <iostream>
#include <stdlib.h>

typedef struct HashTable
{
    int value;
    struct HashTable *next;
} HashTable;

HashTable *hashTable[10] = {0};

/*
 *返回value在哈希表中的下标
 */
int CalcHashTableIndex(int value)
{
    return value%10;
}
/*
 *将关键字value存入hash表中
 */
void PutToHashTable(int value)
{
    int index = CalcHashTableIndex(value);
    HashTable *p = (HashTable *)malloc(sizeof(HashTable));
    p->next = NULL;
    p->value = value;
    if(hashTable[index] == NULL)
    {
        hashTable[index] = p;
        return ;
    }
    p->next = hashTable[index]->next;
    hashTable[index]->next = p;
}
void ShowHashTable()
{
    int i=0;
    for(i=0;i<10;i++)
    {
        HashTable *p = hashTable[i];
        std::cout << i <<":";
        while(p!=NULL)
        {
            std::cout << p->value << "  ";
            p = p->next;
        }
        std::cout << std::endl;
    }
}
int main()
{
    int choice = 0;
    int value = 0;
    while(1)
    {
        std::cout << "1:input a value  2:scan hash table" << std::endl;
        std::cout << "your choice:";
        std::cin >> choice;
        switch(choice)
        {
            case 1: std::cout << "input value:";
                    std::cin >> value;
                    PutToHashTable(value);
                    break;
            case 2: ShowHashTable();
                    break;
        }
    }
    return 0;
}

运行结果
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值