字符串Hash/树Hash学习笔记
哈希
Tags:字符串
作业部落
评论地址
一、概述
百度百科:
散列表(Hash table/哈希表),是根据关键码值(Key value)而直接进行访问的数据结构。
哈希表常用于比较两个字符串是否相同(可以把状态看作字符串,从而比较状态是否相同)
二、实现方式
一个例子
通常将其看成一个进制数,比如\(ABAF\)看成\(1216\),那么哈希值就是\(Hash=1*base^3+2*base^2+1*base+6\),\(base\)可以自由决定,如果说状态量有限,可以使用较小的\(base\)使得所有状态不冲突,若状态量较大且分散,可以采用取模或者自然溢出的方式尽可能避免冲突
优缺点
优点是可以\(O(1)\)比较(数组是\(O(1)\)如果用map就要加一个\(log\))
缺点是会有冲突,为避免冲突可以选择双哈希或三哈希等(选取不同的模数)
哈希方式
1.进制哈希(用于判断状态/数组是否相同)
状态量小时哈希过程可逆(见[一双木棋](https://www.luogu.org/problemnew/show/P4363))
缺点:毒瘤出题人卡自然溢出,采用双哈希
状态量大时哈希过程不可逆(不能通过Hash值还原数组)
使用范围:基本上这么写
>2.树哈希(用于判断树的同构)
$$Hash[x]=\sum_{异或和}(Hash[son_{1...k}]+base1)*(siz[x]+base2)+deep[x]*base3$$其实没有一定要求这么写,只是树的同构要求深度相同,孩子也同构但是与孩子的顺序无关,所以信息就是儿子的$Hash$和深度和大小,可以灵活处理
千古神犇陈菊开安利的一种写法:$$Hash[x]=(\sum{Hash[son]})^{size[x]}\]
注意:base的选取原则是使得Hash值尽可能分散,尽可能少的冲突
优点:这里不用累乘而用异或和,使得Hash过程可逆(也就是在树DP中方便换根/删点)
缺点:没有固定套路,灵活多变(有次考试不管怎么调\(base\)总是过不了,把异或和改成累乘马上就过了,原因是数据范围小,Hash值密集容易造成冲突)
三、题单
- [ ] [AIZU2784]Similarity of Subtrees https://vjudge.net/problem/Aizu-2784
- [x] [BZOJ3197/Luogu3296][SDOI2013]Assassin/刺客信条 https://www.luogu.org/problemnew/show/P3296
- [x] [BZOJ4754/Luogu4323][JSOI2016]独特的树叶 https://www.luogu.org/problemnew/show/P4323
- [x] [BZOJ5248][九省联考2018]一双木棋 https://www.luogu.org/problemnew/show/P4363
- [x] [BZOJ3555]企鹅QQ https://www.luogu.org/problemnew/show/P4503
- [ ] [BZOJ3507/Luogu3167][CQOI2014]通配符匹配 https://www.luogu.org/problemnew/show/P3167
- [ ] [BZOJ4892/Luogu3763][TJOI2017]DNA https://www.luogu.org/problemnew/show/P3763
- [ ] [SDOI2007]游戏 https://www.luogu.org/problemnew/show/P2462
- [ ] [HDU5469]Antonidas https://vjudge.net/problem/HDU-5469
四、代码
// [九省联考2018]一双木棋chess
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<map>
#define ll long long
using namespace std;
int N,M,A[11][11],B[11][11],b[11];
map<ll,int>Map;
ll HASH()
{
ll Hash=0;
for(int i=1;i<=N;i++) Hash=Hash*11+b[i];
return Hash;
}
void ReHash(ll Hash)
{
for(int i=N;i>=1;i--) b[i]=Hash%11,Hash/=11;
}
int DFS(int op,ll Hash)
{
if(Map[Hash]) return Map[Hash]==-1?0:Map[Hash];
ReHash(Hash);int ans=1e9*(-op);
for(int i=1;i<=N;i++)
if(b[i]<b[i-1])
{
b[i]++;int tmp=DFS(-op,HASH());
if(op==1) ans=max(ans,tmp+A[i][b[i]]);
else ans=min(ans,tmp-B[i][b[i]]);
b[i]--;
}
if(ans==1e9*(-op)) ans=0;
Map[Hash]=(ans==0?-1:ans);
return ans;
}
int main()
{
scanf("%d%d",&N,&M);
for(int i=1;i<=N;i++)
for(int j=1;j<=M;j++)
scanf("%d",&A[i][j]);
for(int i=1;i<=N;i++)
for(int j=1;j<=M;j++)
scanf("%d",&B[i][j]);
b[0]=M;
printf("%d\n",DFS(1,0));
return 0;
}
字符串Hash/树Hash学习笔记的更多相关文章
- No1_6.字符串的基本操作2_Java学习笔记
import java.util.Scanner; import java.util.regex.Pattern; public class HelloString2 { public static ...
- No1_5.字符串的基本操作_Java学习笔记
import java.text.DecimalFormat; import java.text.NumberFormat; import java.util.Locale; import java. ...
- 主席树初步学习笔记(可持久化数组?静态区间第k大?)
我接触 OI也快1年了,然而只写了3篇博客...(而且还是从DP跳到了主席树),不知道我这个机房吊车尾什么时候才能摸到大佬们的脚后跟orz... 前言:主席树这个东西,可以说是一种非常畸形的数据结构( ...
- 线段树合并学习笔记(P4556)
直入主题: 学习线段树合并..... 从名字就能看出,这个东西要合并线段树..... 线段树怎么能合并呢...... 暴力合就行了啊...... 一次从上往下的遍历,把所有的节点信息暴力合并,然后就没 ...
- 字典树(Trie)学习笔记
目录 什么是字典树 如何存储字典树 如何查找字符串有没有出现 第一个图的那种线段树 应用 例题 1.统计难题 2.P2580 于是他错误的点名开始了 什么是字典树 上图来自luogu题解 这是一种字典 ...
- BZOJ 3555: [Ctsc2014]企鹅QQ [字符串哈希]【学习笔记】
3555: [Ctsc2014]企鹅QQ Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 2046 Solved: 749[Submit][Statu ...
- BZOJ 1901: Zju2112 Dynamic Rankings[带修改的主席树]【学习笔记】
1901: Zju2112 Dynamic Rankings Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 7143 Solved: 2968[Su ...
- POJ2104 K-th Number[主席树]【学习笔记】
K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Submissions: 51440 Accepted: 17594 Ca ...
- Linxu内核版本号后面多出字符串或者+号【学习笔记】
作者:庄泽彬 之前一直没有留意到但是最近在编译内核的时候版本号竟然多出了个加号+号或字符串, 后面终于找到原因了,原来config如果设置了CONFIG_LOCALVERSION_AUTO=y,内核的 ...
随机推荐
- 机器学习之step by step实战及知识积累笔记
数据工作者工作时间划分 据crowdflower数据科学研究报告,数据科学工作者的时间分配主要在以下几个领域: 首先是数据收集要占20%左右的时间和精力,接着就是数据清洗和再组织需要占用60%的时间. ...
- popup定位引擎popper.js介绍
https://medium.com/@FezVrasta/popper-js-v1-5e8b3acd888c https://survivejs.com/blog/popper-interview/ ...
- java虚拟机---内存
java虚拟机---内存 Java虚拟机,即JVM,负责运行java程序,每个java程序都运行在一个具体jvm实例上.Java虚拟机的体系架构分为:类装载子系统.运行时数据区.执行引擎.类装载子系统 ...
- SQL server数据库压缩空间
SQL server数据库,在手动删除或者自动删除数据后,查看数据库物理文件发现占用空间并没有释放,果断采用万能的重启.(反正是自己用的一个服务器,随便玩.如果不是只有自己用的服务器,还是建议让运维或 ...
- 安装Window Server 2008的些配置
上次安装window server2008,由于server2008需要设置很多东西,不然用起来很不爽,就说IE吧,每次随便打开一个网页都要弹出n多窗口出来叫你添加到信任域里面!太烦人了![下面有解决 ...
- 如何打包ipa文件
如何打包ipa文件 1. 新建一个工程 // // RootViewController.m // YouXianMing // // Copyright (c) 2014年 Y.X. All rig ...
- Python入门-模块1(模块导入与time模块)
---恢复内容开始--- 模块 一.模块分类: 模块分为三种: 1.内置模块:Python自带的标准模块(可使用help('modules’)查看Python自带模块列表) 2.第三方开源模块:可以通 ...
- QtPropertyBrowser+vs2010的安装与配置
之前编译过一次QtPropertyBrowser2.5,见文章http://www.cnblogs.com/aminxu/p/4516469.html,当时很激动,编译成功,lib也都编译通过,程序调 ...
- mysql的表和数据类型
一.查看当前数据库所有表 mysql> use db Database changed mysql> show tables; Empty set (0.00 sec) #表示db数据库下 ...
- ABAP很厉害是怎么一种体验?
知乎上偶然看到这个问题,觉得很有意思,我也来回答一发. 我本科和研究生学的是计算机专业,做项目用C/C++,研究生三年项目的代码量大概在三到四万行左右.2007年大学毕业加入SAP成都研究院一直工作到 ...