• 初始化,数据的行数,hash链表结构体,存储头结点

     #define _CRT_SECURE_NO_WARNINGS
    #include <stdio.h>
    #include <stdlib.h>
    char path[] = "csdn.txt";
    //数据的行数
    #define N 6428633
    //字符串hash算法
    unsigned int BKDRHash(char *str); //hash链表结构体(结构体)
    struct beitai
    {
    char *pstr;//存储字符串
    struct beitai *pNext;//下一个节点
    }; //头结点
    struct info
    {
    struct beitai *pbt;
    }; //保持所有头结点
    struct info *pall = NULL;
  • 字符串hash算法
     //hasn算法
    unsigned int BKDRHash(char *str)
    {
    //和数据对应的位数有关
    unsigned int seed = ; // 31 131 1313 13131 131313 etc..
    unsigned int hash = ; while (*str)
    {
    hash = hash * seed + (*str++);
    } return (hash & 0x7FFFFFFF);
    }
  • 实现读取一行的数据的修改,并对这个字符串进行hash算法
     void changestr(char *str)
    {
    //备份地址
    char *pbak = str;
    //去除空格
    //下标
    int i = ;
    //游标
    int j = ;
    while ((str[i] = str[j++]) != '\0')
    {
    if (str[i] != ' ')
    {
    i++;
    }
    }
    //截断
    char *p1 = strstr(pbak, "#");
    if (p1 != NULL)
    {
    *p1 = '\0';
    }
    }
  • 载入内存
     void init()
    { pall = malloc(N*sizeof(struct info));
    memset(pall, , N*sizeof(struct info));//清空 //打开文件
    FILE *pf = fopen(path, "r");
    for (int i = ; i < N; i++)
    {
    char str[] = { };
    char strbak[] = { };
    //读取一行
    fgets(str, , pf);
    //拷贝
    strcpy(strbak, str);
    //字符串处理
    changestr(str);
    //获取hash对应的数字
    unsigned int data = BKDRHash(str);
    //进行取余
    unsigned int id = data %N;
    pall[id].pbt = addstr(pall[id].pbt, strbak);//找到链表节点,插入
    }
    fclose(pf);
    }
  • 插入节点
     //插入
    struct beitai *addstr(struct beitai *phead, char *str)
    {
    //开辟节点
    struct beitai *pnew = calloc(, sizeof(struct beitai));
    //获取字符串长度并开辟内存
    int length = strlen(str);
    pnew->pstr = calloc(length + , sizeof(char));
    //拷贝
    strcpy(pnew->pstr, str);
    //下一个结点为NULL
    pnew->pNext = NULL;
    //如果头结点为空
    if (phead==NULL)
    {
    phead = pnew;
    }
    //否则头部插入
    else
    {
    pnew->pNext = phead;
    phead = pnew; }
    return phead;
    }
  • 实现查询
     //实现查询
    void find(struct beitai *phead, char *findstr)
    {
    while (phead!=NULL)
    {
    char*ps = strstr(phead->pstr, findstr);
    if (ps!=NULL)
    {
    printf("%s", phead->pstr);//查找
    }
    phead = phead->pNext;
    }
    }
  • 获取有多少行
     int getN()
    {
    FILE *pf = fopen(path, "r");
    if (pf == NULL)
    {
    return -;
    }
    else
    {
    int i = ;
    while (!feof(pf))
    {
    char str[] = { };
    fgets(str, , pf);//读取
    i++;
    }
    fclose(pf);
    return i;
    }
    }
  • 主函数
     //主函数
    void main()
    {
    //初始化并载入内存
    init();
    //查询
    while ()
    {
    char str[] = { };
    scanf("%s", str);
    unsigned int id = BKDRHash(str) % N;
    find(pall[id].pbt, str);
    }
    system("pause");
    }

89.hash算法实现CSDN密码处理的更多相关文章

  1. [区块链] 密码学中Hash算法(基础)

    在介绍Hash算法之前,先给大家来个数据结构中对hash表(散列表)的简单解释,然后我再逐步深入,讲解一下hash算法. 一.Hash原理——基础篇 1.1 概念 哈希表就是一种以 键-值(key-i ...

  2. Hash算法总结(转)

    1. Hash是什么,它的作用先举个例子.我们每个活在世上的人,为了能够参与各种社会活动,都需要一个用于识别自己的标志.也许你觉得名字或是身份证就足以代表你这个人,但是这种代表性非常脆弱,因为重名的人 ...

  3. 关于 Spring Security 5 默认使用 Password Hash 算法

    账户密码存储的安全性是一个很老的话题,但还是会频频发生,一般的做法是 SHA256(userInputpwd+globalsalt+usersalt) 并设置密码时时要求长度与大小写组合,一般这样设计 ...

  4. Hash算法总结

    1. Hash是什么,它的作用 先举个例子.我们每个活在世上的人,为了能够参与各种社会活动,都需要一个用于识别自己的标志.也许你觉得名字或是身份证就足以代表你这个人,但是这种代表性非常脆弱,因为重名的 ...

  5. [区块链] 加密算法——Hash算法(进阶)

    为了为保证存储于区块链中的信息的安全与完整,区块链中使用了包含密码哈希函数和椭圆曲线公钥密码技术在内的大量的现代密码学技术,同时,这些密码学技术也被用于设计基于工作量证明的共识算法并识别用户. 在前边 ...

  6. Hash算法的讲解

    散列表,又叫哈希表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash ta ...

  7. 从hash算法到java hashcode()

    转载 https://blog.csdn.net/Walk_er/article/details/74976146 hash算法是一个摘要算法(yy:描述性算法:可以给一个物体确切的描述,但是不能通过 ...

  8. 深入理解 hashcode 和 hash 算法

    深入理解 hashcode 和 hash 算法 2017年12月30日 23:06:07 阅读数:5197 标签: hashhashmaphashcode二进制 更多 个人分类: jdk-源码  ht ...

  9. 常见的哈希Hash算法 & MD5 & 对称非对称加密 & 海明码

    参考 Link 另外,这篇文章也提到了利用Hash碰撞而产生DOS攻击的案例: http://www.cnblogs.com/charlesblc/p/5990475.html DJB的算法实现核心是 ...

随机推荐

  1. 深入理解Android(5)——从MediaScanner分析Android中的JNI

    前面几篇介绍了Android中的JNI和基本用法,这一篇我们通过分析Android源代码中的JNI实例,来对JNI部分做一个总结. 一.通向两个不同世界的桥梁 在前面我们说过,JNI就像一个桥梁,将J ...

  2. 分享js中的 sort 另一种用法

    // 看上去正常的结果: ['Google', 'Apple', 'Microsoft'].sort(); // ['Apple', 'Google', 'Microsoft']; // apple排 ...

  3. CodeBlocks 配色方案

    搜索<colour_sets>,在</ACTIVE_LANG>下加入: 有几种经典方案,包括vim,desert,sublime,ulipad,oblivion,darkgra ...

  4. Bootstrap Table 的用法

    记录下 Bootstrap Table 的用法,备忘. <!DOCTYPE html> <html> <head> <meta charset="u ...

  5. SpringBoot结合Mybatis 使用 mapper*.xml 进行数据库增删改查操作

    什么是 MyBatis? MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索. MyBa ...

  6. HBase写入操作卡住长时间不返回的原因分析

    本文出处:http://blog.csdn.net/chaijunkun/article/details/44238163,转载请注明. 由于本人不定期会整理相关博文,会对相应内容作出完好.因此强烈建 ...

  7. spring set注入

    上篇文章说到了构造器注入.可是有时候构造器注入并非非常好用,如今来看下set注入. 构造器注入博客地址:http://blog.csdn.net/luckey_zh/article/details/4 ...

  8. Docker+Jenkins持续集成

    Docker+Jenkins持续集成 使用etcd+confd实现容器服务注册与发现   前面我们已经通过jenkins+docker搭建了基本的持续集成环境,实现了服务的自动构建和部署,但是,我们遇 ...

  9. 移动端meta几个值的设置以及含义

    <!-- 为移动设备添加 viewport --> <meta name="viewport" content="width=device-width, ...

  10. 56.lambda表达式与绑定以及伪函数和绑定

    #include <iostream> #include <functional> using namespace std; using namespace std::plac ...