• 初始化,数据的行数,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. ADO.NET数据读取封装

    public class sqlserver { //private string sqlstr = System.ConfigurationManager.ConnectionStrings[&qu ...

  2. 分享vue中 slot用法

    //slot默认用法 //slot带参数name用法

  3. Oracle 删除重复数据的几种方法

    去重 第一种:distinct create table tmp_t3 as select distinct * from t3; drop table t3; alter table tmp_t2 ...

  4. Bit、Byte、kb、KB、MB、KiB、MiB各表示什么意思?

    1.Byte.bit:bit表示:位,是计算机中最小的数据单位.每一位的状态只能是0或1Byte表示:字节,8个二进制位构成1个字节,即1 Byte = 8 bit .1个英文字母或者数字占用1个字节 ...

  5. struts2的字符串参数

    一定要熟记一个东西,一层引号的是变量,两层引号的是字符串 如"蓝"/'蓝'是变量,而" '蓝' "/ ' "蓝" '是字符串 打代码时要警惕 ...

  6. 读书笔记-深入理解JVM虚拟机-1.OOM初探

    Java堆OOM(Out-Of-Memory)异常 执行例如以下程序,爆出异常 java.lang.OutOfMemoryError: Java heap space /** * VM Args:-X ...

  7. Netty In Action中文版 - 第七章:编解码器Codec

    http://blog.csdn.net/abc_key/article/details/38041143 本章介绍 Codec,编解码器 Decoder,解码器 Encoder,编码器 Netty提 ...

  8. LeetCode Implement strStr()(Sunday算法)

    LeetCode解题之Implement strStr() 原题 实现字符串子串匹配函数strStr(). 假设字符串A是字符串B的子串.则返回A在B中首次出现的地址.否则返回-1. 注意点: - 空 ...

  9. Onvif开发之服务端成功对接Rtsp视频流篇

    前面篇介绍onvif服务端的发现功能,继续在之前的代码基础上完成一个RTSP流的工作,也就是客户端通过ONVIF协议来预览设备端在这个之前必须确定几个简单的条件1 设备端能被发现2 设备端支持RTSP ...

  10. linux的vi或vim文件时,怎样消除刚才查找字符串的高亮?

    有时候,自己在通过/查找字符串时,会出现: 但是呢,当你保存,再次进入还是会出现这么花的高亮显示,很令人苦恼. 解决办法 随便,输入没有的字符串,即可解决. 如下 /sssssssssssssssss ...