这里使用了编号代替真实的数据,只用来表示算法

#ifndef HASH_DATA_T
#define HASH_DATA_T int
#endif      //HASH_DATA_T
typedef struct node_t{
    HASH_DATA_T* data;
    int num;
    struct node_t* next;
}node_t;
typedef struct{
    node_t** table;     //数组指针表示hash表
    int maxlen;
}hash_t;
//创建hash表
hash_t* create_hash(int len){
    hash_t* H=(hash_t*)malloc(sizeof(hash_t));
    H->table=(node_t**)malloc(len*sizeof(node_t*));
    H->maxlen=len;
    int i=0;
    for(i=0;i<len;i++){
        H->table[i]=(node_t*)malloc(sizeof(node_t));
        H->table[i]->next=NULL;
    }
    return H;
}
//插入数据(编号)
int insert_hash(hash_t* H,int num){ //用编号代替了数据,需要其他数据的时候扩展一下就好
    //对表单的个数取余,获得key
    int key=num%H->maxlen;
    node_t* pNode=H->table[key];
    //封装节点
    node_t* tmp=(node_t*)malloc(sizeof(node_t));
    tmp->num=num;
    for(pNode=H->table[key];pNode!=NULL;pNode=pNode->next){
        if(NULL==pNode->next||pNode->next->num>tmp->num){
            tmp->next=pNode->next;
            pNode->next=tmp;
            return 0;
        }
    }
    return -2;
}

//显示表
int show_hash(hash_t* H){
    int i=0;
    node_t* pNode=NULL;
    for(i=0;i<H->maxlen;i++){
        for(pNode=H->table[i]->next;pNode!=NULL;pNode=pNode->next){
            printf("%d ",pNode->num);
        }
        putchar(10);
        puts("+++++++++++");
    }
    return 0;
}
//查找数据
int search_hash(hash_t* H, int num){
    node_t* pNode=NULL;
    int i=0;
    for(i=0;i<H->maxlen;i++){
        for(pNode=H->table[i]->next;pNode!=NULL;pNode=pNode->next){
            if(pNode->num==num){
                printf("%d ",pNode->num);
            }
        }
        putchar(10);
        puts("+++++++++++");
    }
    return 0;
}
//销毁hash表
int destroy_hash(hash_t* hash){
    int i=0;
    for(i=0;i<hash->maxlen;i++){
        free(hash->table[i]);
        hash->table[i]=NULL;
    }
    free(hash->table);
    hash->table=NULL;
    free(hash);
    hash=NULL;
}

hash查找的更多相关文章

  1. 二分查找和hash查找

    转载:http://blog.csdn.net/feixiaoxing/article/details/6844723 无论是数据库,还是普通的ERP系统,查找功能数据处理的一个基本功能.数据查找并不 ...

  2. Hash查找法在Keil C51中的实现

    摘要:散列(hash)是一种重要的存储方法,也是一种常见的查找方法.它是指在记录的存储位置和它的关键字之间建立一个确定的对应关系.本文以射频卡门禁控制器为例,说明用射频卡卡号作为关键字,用Hash查找 ...

  3. 9.算法之顺序、二分、hash查找

    一.查找/搜索 - 我们现在把注意力转向计算中经常出现的一些问题,即搜索或查找的问题.搜索是在元素集合中查找特定元素的算法过程.搜索通常对于元素是否存在返回 True 或 False.有时它可能返回元 ...

  4. 查找算法(顺序查找、二分法查找、二叉树查找、hash查找)

    查找功能是数据处理的一个基本功能.数据查找并不复杂,但是如何实现数据又快又好地查找呢?前人在实践中积累的一些方法,值得我们好好学些一下.我们假定查找的数据唯一存在,数组中没有重复的数据存在. (1)顺 ...

  5. 协议栈处理中的conntrack HASH查找/Bloom过滤/CACHE查找/大包与小包/分层处理风格

    1.路由CACHE的优势与劣势 分级存储体系已经存在好多年了.其精髓在于"将最快的存储器最小化.将最慢的存储器最大化",这样的结果就使资源利用率的最大化.既提高了訪问效率,又节省了 ...

  6. 算法之顺序、二分、hash查找

    算法之顺序.二分.hash查找   一.查找/搜索 - 我们现在把注意力转向计算中经常出现的一些问题,即搜索或查找的问题.搜索是在元素集合中查找特定元素的算法过程.搜索通常对于元素是否存在返回 Tru ...

  7. POJ 1200 Crazy Search 字符串的Hash查找

    第一次涉及HASH查找的知识 对于字符串的查找有很多前人开发出来的HASH函数,比较常用的好像是ELF 和 BKDR. 这道题没想到突破点是在于其nc值,告诉你组成字符串的字母种类. 还有用26进制, ...

  8. 查找算法----二分查找与hash查找

    二分查找 有序列表对于我们的实现搜索是很有用的.在顺序查找中,当我们与第一个元素进行比较时,如果第一个元素不是我们要查找的,则最多还有 n-1 个元素需要进行比较. 二分查找则是从中间元素开始,而不是 ...

  9. 海量路由表能够使用HASH表存储吗-HASH查找和TRIE树查找

    千万别! 非常多人这样说,也包括我. Linux内核早就把HASH路由表去掉了.如今就仅仅剩下TRIE了,只是我还是希望就这两种数据结构展开一些形而上的讨论. 1.hash和trie/radix ha ...

随机推荐

  1. 第 21 章 CSS3 文本效果

    学习要点: 1.文本阴影 2.文本裁剪 3.文本描边 4.文本填充 主讲教师:李炎恢 本章主要探讨 HTML5 中 CSS3 中文本效果,其中也包含一些之前讲过的 CSS3 文本属性. 一.文本阴影 ...

  2. PostgreSQL类型转换

    1.int装string select CAST (1234 AS text) select to_char(1234,’999‘) 2.string转int select cast('999' as ...

  3. (学习笔记)HTML的<link>标签

    在HTML中<link>标签用于定义文档与外部资源的关系. <link>标签只存在于head部分. <head> <link rel="styles ...

  4. [moka同学笔记]Yii2 数据操作Query Builder 2

    Query Builder $rows = (new \yii\db\Query()) ->select(['dyn_id', 'dyn_name']) ->from('zs_dynast ...

  5. 【Effective Java】8、优先考虑类型安全的异构容器

    有的时候我们一个容器只有一个类型或几个类型并不能满足我们的要求,比如set中存放的元素类型都是同一种,map也就指定的两种 这里我们可以将键进行参数化,而不是将容器参数化,也就是我们可以给容器传一个键 ...

  6. socket.io,环境搭建 & Hello world

    原文:http://www.cnblogs.com/xiezhengcai/p/3955827.html socket.io 一个与服务器实时通信的工具,它与原生的webSocket相比,具有更可靠. ...

  7. angular学习的一些小笔记(中)之双向数据绑定

    <!doctype html> <html ng-app=""> <head> <script src="https://aja ...

  8. 20个优秀的 JavaScript 键盘事件处理库

    键盘事件是 Web 开发中最常用的事件之一,通过对键盘事件的捕获和处理可以提高网站的易用性和交互体验.下面,我们向大家介绍收集的20款优秀的 JavaScript 键盘事件处理库,帮助开发人员轻松处理 ...

  9. 免费素材:包含 250+ 组件的 DO UI Kit

    DO UI kit 现在可以免费用于 Photoshop 和 Sketch 了.它有超过130个屏幕,10个完整的主题以及250+的组件混合以创造惊人的应用.他们都是再混合和视网膜.最重要的是他们看起 ...

  10. div水平居中

    1.先给它外层的div定位并left:position:absolute;left:50%; 2.获取当前元素div的宽度,并除以2 3.改变它的css:margin-left:-(获取当前元素div ...