先说一下我自己的理解。

我先给你N组数据,这个N组里可能有重复的!

然后我们先统计好了N组里面的独立的每个对应的出现了几次(相当于map,然后每项属性有出现了多少次的),用的是数组下标对应

现在我们给了M个名字,要看这个出现了几次

就直接返回数组下标对应的数

但是呢,这个数组可能会太长了,我们就用一些方法,比如求余,让这组数尽量紧凑起来。

但是求余会导致得到同样的结果,处理的方法有H(key)+1,+2..或者H(key)+1^2 再或者用一个链表,把H(key)相同的存起来。

  1. 散列的定义与整数散列

    给定数组N和数组M,要查询M中的数字是否在N中出现过,用空间换时间,建立一个哈希表,如果被查询数组N中有这个数字x,就将哈希表的第x个bool值改为true,不然就是false。

    然后一边读入M中的数字,一边看哈希表中对应位置是不是为true,如果是就输出。
#include <iostream>
const int maxn = 100000;
bool hashtable[maxn] = {false}; //一次将所有的置为false int main()
{
// for (int i = 0; i < 10; i++)
// {
// if (hashtable[i] == false)
// {
// printf("Yes\n");
// }
// }
int m, n, x;
scanf("%d%d", &n, &m);
for (int i = 0; i < n; i++)
{
scanf("%d", &x);
hashtable[x] = true;
}
for (int i = 0; i < m; i++)
{
scanf("%d", &x);
if (hashtable[x] == true)
{
printf("%d\n",x);
}
}
system("pause");
}

如果要看查询表M中的元素,在被查询N数组中出现的次数,把hashtable设置为int型。

#include <iostream>
const int maxn = 100000;
int hashtable[maxn]; int main()
{
memset(hashtable,0,sizeof(hashtable));
int m, n, x;
scanf("%d%d", &n, &m);
for (int i = 0; i < n; i++)
{
scanf("%d", &x);
hashtable[x]++;
}
for (int i = 0; i < m; i++)
{
scanf("%d", &x);
printf("%d\n", hashtable[x]);
}
system("pause");
}

2.字符串hash

字母用用把字母转化到十进制数,然后再用1的方法。

给出N个字符串统计,给出M个查询串,问每个查询串在N个字符串种出现的次数。

hashtable是262626,因为26进制转化后最大为(26^2+26+1)*25(注意是25),变化为1,开始为000.

#include <iostream>
#include <string.h>
using namespace std;
const int maxn = 100; //设置被查询串个数
char s[maxn][5]; //字典,3位大写英文,有maxn组
char temp[5];
int hashtable[26*26*26 + 10]; int hashFunc(char a[], int len)
{
int id = 0;
for (int i = 0; i < len; i++)
{
id = (a[i] - 'A') + id*26;
}
return id;
} int main()
{
memset(hashtable,0,sizeof(hashtable));
//输入输出
int m, n; //m个查询串,n个被查询串(字典)
scanf("%d%d", &m, &n);
//建立字典
for (int i = 0; i < n; i++)
{
scanf("%s", s[i]);
hashtable[hashFunc(s[i], 3)]++;
} for (int i = 0; i < m; i++)
{
scanf("%s", temp);
int t = hashFunc(temp, 3);
printf("%d\n", hashtable[t]);
}
system("pause");
}

【C/C++】散列/算法笔记4.2的更多相关文章

  1. Android数据加密之SHA安全散列算法

    前言: 对于SHA安全散列算法,以前没怎么使用过,仅仅是停留在听说过的阶段,今天在看图片缓存框架Glide源码时发现其缓存的Key采用的不是MD5加密算法,而是SHA-256加密算法,这才勾起了我的好 ...

  2. 个人理解c#对称加密 非对称加密 散列算法的应用场景

    c#类库默认实现了一系列加密算法在System.Security.Cryptography; 命名空间下 对称加密 通过同一密匙进行加密和解密.往往应用在内部数据传输情况下.比如公司a程序 和B程序 ...

  3. C# SHA1散列算法

    C# SHA1散列算法 /// <summary> /// C# SHA1散列算法 /// </summary> /// <param name="str&qu ...

  4. SHA安全散列算法简析

    1 SHA算法简介 1.1 概述 SHA (Secure Hash Algorithm,译作安全散列算法) 是美国国家安全局 (NSA) 设计,美国国家标准与技术研究院(NIST) 发布的一系列密码散 ...

  5. shiro进行散列算法操作

    shiro最闪亮的四大特征:认证,权限,加密,会话管理 为了提高应用系统的安全性,这里主要关注shiro提供的密码服务模块: 1.加密工具类的熟悉 首先来个结构图,看看shiro提供了哪些加密工具类: ...

  6. [转帖]什么是安全散列算法SHA256?

    什么是安全散列算法SHA256? http://8btc.com/article-136-1.html 发布者: 无主之地 发表于: 2013-10-1 01:31 78152 2 分享   安全散列 ...

  7. shiro中自定义realm实现md5散列算法加密的模拟

    shiro中自定义realm实现md5散列算法加密的模拟.首先:我这里是做了一下shiro 自定义realm散列模拟,并没有真正链接数据库,因为那样东西就更多了,相信学到shiro的人对连接数据库的一 ...

  8. 什么是安全散列算法SHA256?

    安全散列算法SHA(Secure Hash Algorithm)是美国国家安全局 (NSA) 设计,美国国家标准与技术研究院(NIST) 发布的一系列密码散列函数,包括 SHA-1.SHA-224.S ...

  9. java学习-sha1散列算法

    直接调用HashKit.sha1(String str)方法就可以了,,返回的是16进制的字符串长度是40, 也就是用md.digest()方法解析出来的字节数是160字节长度. 而MD5散列算法生成 ...

随机推荐

  1. FZU ICPC 2020 寒假训练 5 —— 排序

    P1177 [模板]快速排序 题目描述 利用快速排序算法将读入的 N 个数从小到大排序后输出.快速排序是信息学竞赛的必备算法之一.对于快速排序不是很了解的同学可以自行上网查询相关资料,掌握后独立完成. ...

  2. JS表格显示时间格式

    <!-- JS代码区 --> <script type='text/javascript'> $(function() { var grid_selector23 = &quo ...

  3. ubuntu 首次登陆设置root密码

    用过ubuntu的人都知道,ubuntu默认root密码是随机的,即每次开机都有一个新的root密码.我们可以在终端输入命令sudo passwd,然后输入当前用户的密码   给root用户设置密码 ...

  4. ESP32-S3 搭建 micropython 开发环境,固件编译,烧录

    简述 上手了一块乐鑫科技官方推出的ESP32-S3-DevKitC-1开发板,发现 ESP32-S3 的综合性能较比前两代有着非常明显的提升,wifi与蓝牙功能,更充足的外设扩展能力,可以看出其在未来 ...

  5. Vue: 一个简单的Vue2.0 v-model双向数据绑定的实现,含源代码,小白也能看懂

    首先说一下原理吧 View层(dom元素)的变动如何响应到Model层(Js变量)呢? 通过监听元素的input事件来动态的改变js变量的值,实际上不是改变的js变量的值,而是改变的js变量的gett ...

  6. 详解在Linux中安装配置MongoDB

    最近在整理自己私人服务器上的各种阿猫阿狗,正好就顺手详细记录一下清理之后重装的步骤,今天先写点数据库的内容,关于在Linux中安装配置MongoDB 说实话为什么会装MongoDB呢,因为之前因为公司 ...

  7. Codeforces 848E - Days of Floral Colours(分治 FFT)

    Codeforces 题目传送门 & 洛谷题目传送门 神仙 D1E,一道货真价实的 *3400 %%%%%%%%%%%% 首先注意到一点,由于该图为中心对称图形,\(1\sim n\) 的染色 ...

  8. plink 进行PCA分析

    当我们进行群体遗传分析时,得到vcf后,可利用plink进行主成分(PCA)分析: 一.软件安装 1 conda install plink 二.使用流程 第一步:将vcf转换为plink格式 1 p ...

  9. mingling

    mysql> USE mon Reading table information for completion of table and column names You can turn of ...

  10. 爬虫动态渲染页面爬取之Splash的介绍和使用

    Splash是一个JavaScript渲染服务,是一个带有HTTP API的轻量级浏览器,同时它对接了Python中的Twisted和QT库.利用它,我们同样可以实现动态渲染页面的抓取. 1. 功能介 ...