【POJ3349 Snowflake Snow Snowflakes】【Hash表】
最近在对照省选知识点自己的技能树 今天是Hash
题面
大概是给定有n个6元序列
定义两个序列相等 当两个序列各自从某一个元素开始顺时针或者逆时针旋转排列能得到两个相同的序列
求这n个6元序列中是否有相等的序列
解释相等序列的样例
顺时针:如 1 2 3 4 5 6 与 2 3 4 5 6 1 相等
逆时针:如 1 2 3 4 5 6 与 6 5 4 3 2 1 相等
算法
对于各种类型的数列 字符串是否相等问题我们都可以用Hash解决
我们对一个序列A 定义其哈希值为 \(H(A) = (\sum^{6}_{j = 1}A_{i,j} + \prod^{6}_{j = 1}A_{i,j}) mod P\)
P的取值稍后讨论
我们知道对于组成数字一样的两个序列A和B 显然有\(H(A) = H(B)\)
我们用领接表来存储这些哈希值相等的序列在总序列中的下标,然后我们把当前序列A与在哈希表中哈希值同A一样的序列进行比较即可
如果没有匹配的 我们则把A的首个元素下标 存入哈希表
P的取值
在哈希表中 我们通常取P与数据范围N接近的质数 这样可以让哈希表尽量的均匀 可以提高查找效率 这里最大的数据范围是 600000 我们取\(P = 517619\)
代码
#include <iostream>
#include <cstdio>
#define ll long long
#define M 600010
#define MOD 517619
using namespace std;
ll num[M], n, head[M];
struct P {
ll biao, next;
} lian[M];
bool cheek(ll n1, ll n2) {
bool p;
for (ll i = 1; i <= 6; i++) //顺
{
p = 1;
for (ll j = 1; j <= 6; j++) {
ll now = n1 + (i + j - 1) % 6;
if (num[now] != num[n2 + j - 1]) {
p = 0;
break;
}
}
if (p)
return 1;
}
for (ll i = 1; i <= 6; i++) //逆
{
p = 1;
for (ll j = 1; j <= 6; j++) {
ll now = n1 + (i + j - 1) % 6;
if (num[now] != num[n2 + 6 - j]) {
p = 0;
break;
}
}
if (p)
return 1;
}
return 0;
}
bool insert(ll num, ll front) {
ll now = head[num];
if (now == 0) {
lian[++lian[0].biao].biao = front;
lian[lian[0].biao].next = head[num];
head[num] = lian[0].biao;
return 0;
} else
for (; now; now = lian[now].next) {
if (cheek(lian[now].biao, front))
return 1;
}
lian[++lian[0].biao].biao = front;
lian[lian[0].biao].next = head[num];
head[num] = lian[0].biao;
return 0;
}
int main() {
scanf("%lld", &n);
for (ll i = 1; i <= 6 * n; i += 6) {
ll sum = 0;
ll cheng = 1;
for (ll j = 1; j <= 6; j++) {
scanf("%lld", &num[i + j - 1]);
sum = (sum + num[i + j - 1]) % MOD;
cheng = (cheng * num[i + j - 1]) % MOD;
}
ll key = (sum + cheng) % MOD;
if (insert(key, i)) {
puts("Twin snowflakes found.");
return 0;
}
}
puts("No two snowflakes are alike.");
}
```(奇怪 代码块渲染出了点问题)
【POJ3349 Snowflake Snow Snowflakes】【Hash表】的更多相关文章
- POJ3349: Snowflake Snow Snowflakes(hash 表)
考察hash表: 每一个雪花都有各自的6个arm值,如果两个雪花从相同或者不同位置开始顺时针数或者逆时针数可以匹配上,那么这两个雪花就是相等的. 我们采用hash的方法,这样每次查询用时为O(1),总 ...
- [poj3349]Snowflake Snow Snowflakes(hash)
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 37615 Accepted: ...
- POJ--3349 Snowflake Snow Snowflakes(数字hash)
链接:Snowflake Snow Snowflakes 判断所有的雪花里面有没有相同的 每次把雪花每个角的值进行相加和相乘 之后hash #include<iostream> #incl ...
- poj3349 Snowflake Snow Snowflakes【HASH】
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 49991 Accep ...
- POJ3349 Snowflake Snow Snowflakes (hash
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 48624 Accep ...
- POJ3349 Snowflake Snow Snowflakes 【哈希表】
题目 很简单,给一堆6元组,可以从任意位置开始往任意方向读,问有没有两个相同的6元组 题解 hash表入门题 先把一个六元组的积 + 和取模作为hash值,然后查表即可 期望\(O(n)\) #inc ...
- poj3349 Snowflake Snow Snowflakes —— 哈希表
题目链接:http://poj.org/problem?id=3349 题意:雪花有6个瓣,有n个雪花,输入每个雪花的瓣长,判断是否有一模一样的雪花(通过旋转或翻转最终一样,即瓣长对应相等).如果前面 ...
- poj3349 Snowflake Snow Snowflakes
吼哇! 关于开散列哈希: 哈希就是把xxx对应到一个数字的东西,可以理解成一个map<xxx, int>(是不是比喻反了) 我们要设计一个函数,这个函数要确保同一个东西能得到相同的函数值( ...
- POJ 3349 Snowflake Snow Snowflakes Hash
题目链接: http://poj.org/problem?id=3349 #include <stdio.h> #include <string.h> #include < ...
随机推荐
- javascript-jquery-更改jquery对象
在许多情况下,jquery代码所做的事情变成了:生成jquery对象A,操作对jquery象A:更改为jquery对象B,操作jquery对象B:更改为jqueryC,操作jquery对象C..... ...
- Noip模拟37 2021.8.12
T1 数列 真是考场上不是数学的乱推柿子,想定理,是数学的没想出来.. 比较悲伤... 列柿子不用动脑子,就是没有想出来$EXgcd$解不定方程,淦.. 解处一组解后利用比较显然的性质: $x+\fr ...
- 2021.10.10考试总结[NOIP模拟73]
T1 小L的疑惑 对于\(P_i\),如果所有比\(P_i\)小的数加起来也达不到\(P_i-1\),那么值域肯定不连续.否则设原来值域最大值为\(mx\),则\(P_i\)会让值域最大值增致\(mx ...
- BF算法和KMP算法
这两天复习数据结构(严蔚敏版),记录第四章串中的两个重要算法,BF算法和KMP算法,博主主要学习Java,所以分析采用Java语言,后面会补上C语言的实现过程. 1.Brute-Force算法(暴力法 ...
- 转:Modelsim和Vcs+Verdi使用技巧(Linux)
Modelsim脚本自动仿真 1.创建文件 run.do,"#"为注释符号 quit -sim #退出上次仿真 .main clear #清除上次仿真所有文件以及打印信息 vlib ...
- Python import Queue ImportError: No module named 'Queue'
python3 中引入Queue 会报出这个问题 python3 中这样引入 import queue python2 中这样引入 import Queue 为了兼容 可以这样 import sys ...
- hdu 1027 Ignatius and the Princess II(正、逆康托)
题意: 给N和M. 输出1,2,...,N的第M大全排列. 思路: 将M逆康托,求出a1,a2,...aN. 看代码. 代码: int const MAXM=10000; int fac[15]; i ...
- 第01课 OpenGL窗口(1)
教程的这一节在2000年一月彻底重写了一遍.将会教您如何设置一个 OpenGL窗口.它可以只是一个窗口或是全屏幕的.可以任意 大小.任意色彩深度.此处的代码很稳定且很强大,您可以在您所有的OpenGL ...
- laravel常用查询
插入 DB::table('t_admin_users')->insert([ [ 'role_id' => $allData['roleId'], 'username' => $a ...
- Spring一套全通—工厂
百知教育 - Spring系列课程 - 工厂 第一章 引言 1. EJB存在的问题 2. 什么是Spring Spring是一个轻量级的JavaEE解决方案,整合众多优秀的设计模式 轻量级 1. 对于 ...