哈希表的应用实例 C语言实现

转载:https://blog.csdn.net/zouchunlaigo1988/article/details/7163920   但原文代码有瑕疵,略作修改。但是仍有不足之处,

如姓名fuzongkai和姓名luzhijian及姓名xujinfeng的关键字均为974.

#include<stdio.h>

#define NAME_NO 30
#define HASH_LENGTH 50
#define M 50;

typedef struct
{
    char *py;      //名字的拼音
    int k;         //名字拼音所对应的ASCII码的和
}NAME;


typedef struct         //哈希表
{
    char *py;     //名字的拼音
    int k;        //拼音所对应的ASCII码的和
    int si;       //查找长度
}HASH;

NAME NameList[NAME_NO];
HASH HashList[HASH_LENGTH];


void InitNameList()
{
    char *f;
    int r, s0, i;
    NameList[0].py = "chenliang";//陈亮
    NameList[1].py = "chenyuanhao";//陈元浩
    NameList[2].py = "chengwenliang";//程文亮
    NameList[3].py = "dinglei";//丁磊
    NameList[4].py = "fenghanzao";//冯汉枣
    NameList[5].py = "fuzongkai";//付宗楷
    NameList[6].py = "hujingbin";//胡劲斌
    NameList[7].py = "huangjianwu";//黄建武
    NameList[8].py = "lailaifa";//赖来发
    NameList[9].py = "lijiahao";//李嘉豪
    NameList[10].py = "liangxiaocong";//梁晓聪
    NameList[11].py = "linchunhua";//林春华
    NameList[12].py = "liujianhui";//刘建辉
    NameList[13].py = "luzhijian";//卢志健
    NameList[14].py = "luonan";//罗楠
    NameList[15].py = "quegaoxiang";//阙高翔
    NameList[16].py = "sugan";//苏淦
    NameList[17].py = "suzhiqiang";//苏志强
    NameList[18].py = "taojiayang";//陶嘉阳
    NameList[19].py = "wujiawen";//吴嘉文
    NameList[20].py = "xiaozhuomin";//肖卓明
    NameList[21].py = "xujinfeng"; //许金峰
    NameList[22].py = "yanghaichun";//杨海春
    NameList[23].py = "yeweixiong";//叶维雄
    NameList[24].py = "zengwei";//曾玮
    NameList[25].py = "zhengyongbin";//郑雍斌
    NameList[26].py = "zhongminghua";//钟明华
    NameList[27].py = "chenliyan";//陈利燕
    NameList[28].py = "liuxiaohui";//刘晓慧
    NameList[29].py = "panjinmei";//潘金梅
    for (i = 0; i < NAME_NO; i++)
    {
        s0 = 0;
        f = NameList[i].py;
        for (r = 0; *(f + r) != '\0'; r++)/*将字符串的各个字符所对应的ASCII码相加,所得的整数做为哈希表的关键字*/
            s0 = *(f + r) + s0;

        NameList[i].k = s0;
    }

}

void CreateHashList()
{
    int i;
    for (i = 0; i < HASH_LENGTH; i++)
    {
        HashList[i].py = "";
        HashList[i].k = 0;
        HashList[i].si = 0;
    }
    for (i = 0; i < NAME_NO; i++)
    {
        int sum = 0;
        int adr = (NameList[i].k) % M;//哈希函数
        int d = adr;
        if (HashList[adr].si == 0)//如果不冲突
        {
            HashList[adr].k = NameList[i].k;
            HashList[adr].py = NameList[i].py;
            HashList[adr].si = 1;
        }
        else//冲突  
        {
            do
            {
                d = (d + NameList[i].k % 10 + 1) % M;//伪随机探测再散列法处理冲突    
                sum = sum + 1;                 //查找次数加1    
            } while (HashList[d].k != 0);
            HashList[d].k = NameList[i].k;
            HashList[d].py = NameList[i].py;
            HashList[d].si = sum + 1;
        }
    }

}

void  FindList() //查找    
{
    char name[20] = { 0 };
    int s0 = 0, r, sum = 1, adr, d;
    printf("请输入姓名的拼音:");
    scanf("%s", name);
    for (r = 0; r < 20; r++)   //求出姓名的拼音所对应的整数(关键字)
        s0 += name[r];
    adr = s0 % M;   //使用哈希函数
    d = adr;
    if (HashList[adr].k == s0)          //分3种情况进行判断
        printf("\n姓名:%s   关键字:%d   查找长度为: 1", HashList[d].py, s0);
    else if (HashList[adr].k == 0)
        printf("无此记录!");
    else
    {
        int g = 0;
        do
        {
            d = (d + s0 % 10 + 1) % M;       //伪随机探测再散列法处理冲突                     
            sum = sum + 1;
            if (HashList[d].k == 0)
            {
                printf("无此记录! ");
                g = 1;
            }
            if (HashList[d].k == s0)
            {
                printf("\n姓名:%s   关键字:%d   查找长度为:%d", HashList[d].py, s0, sum);
                g = 1;
            }
        } while (g == 0);
    }

}

void Display()
{
    int i;
    float average = 0;
    printf("\n地址\t关键字\t\t搜索长度\tH(key)\t 姓名\n"); //显示的格式
    for (i = 0; i < 50; i++)
    {
        printf("%d ", i);
        printf("\t%d ", HashList[i].k);
        printf("\t\t%d ", HashList[i].si);
        printf("\t\t%d ", HashList[i].k % 30);
        printf("\t %s ", HashList[i].py);
        printf("\n");
    }
    for (i = 0; i < HASH_LENGTH; i++)
        average += HashList[i].si;
    average /= NAME_NO;

}

int main()
{
    char ch1;
    InitNameList();
    CreateHashList();
    do
    {
        printf("\nD. 显示哈希表\nF. 查找\nQ. 退出\n请选择: ");
        scanf("%c", &ch1);
        switch (ch1)
        {
        case 'D':Display(); printf("\n"); break;
        case 'F':FindList(); printf("\n"); break;
        case 'Q':exit(0);
        }
        printf( "come on !(y/n):");
        scanf("%c", &ch1);
    } while (ch1 != 'n');

    
        

    system("pause");
    return 0;
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值