最近在对照省选知识点自己的技能树 今天是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表】的更多相关文章

  1. POJ3349: Snowflake Snow Snowflakes(hash 表)

    考察hash表: 每一个雪花都有各自的6个arm值,如果两个雪花从相同或者不同位置开始顺时针数或者逆时针数可以匹配上,那么这两个雪花就是相等的. 我们采用hash的方法,这样每次查询用时为O(1),总 ...

  2. [poj3349]Snowflake Snow Snowflakes(hash)

    Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 37615 Accepted: ...

  3. POJ--3349 Snowflake Snow Snowflakes(数字hash)

    链接:Snowflake Snow Snowflakes 判断所有的雪花里面有没有相同的 每次把雪花每个角的值进行相加和相乘 之后hash #include<iostream> #incl ...

  4. poj3349 Snowflake Snow Snowflakes【HASH】

    Snowflake Snow Snowflakes Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 49991   Accep ...

  5. POJ3349 Snowflake Snow Snowflakes (hash

    Snowflake Snow Snowflakes Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 48624   Accep ...

  6. POJ3349 Snowflake Snow Snowflakes 【哈希表】

    题目 很简单,给一堆6元组,可以从任意位置开始往任意方向读,问有没有两个相同的6元组 题解 hash表入门题 先把一个六元组的积 + 和取模作为hash值,然后查表即可 期望\(O(n)\) #inc ...

  7. poj3349 Snowflake Snow Snowflakes —— 哈希表

    题目链接:http://poj.org/problem?id=3349 题意:雪花有6个瓣,有n个雪花,输入每个雪花的瓣长,判断是否有一模一样的雪花(通过旋转或翻转最终一样,即瓣长对应相等).如果前面 ...

  8. poj3349 Snowflake Snow Snowflakes

    吼哇! 关于开散列哈希: 哈希就是把xxx对应到一个数字的东西,可以理解成一个map<xxx, int>(是不是比喻反了) 我们要设计一个函数,这个函数要确保同一个东西能得到相同的函数值( ...

  9. POJ 3349 Snowflake Snow Snowflakes Hash

    题目链接: http://poj.org/problem?id=3349 #include <stdio.h> #include <string.h> #include < ...

随机推荐

  1. NX Open,怎样取到面的环LOOP

    在封装的ufun .NET库里面,对UF_MODL_ask_face_loops这个函数并没有封装,导致我们很多不便,那我们在.NET下怎样才能使用这个函数呢??当然是手动处理一下 Public Fu ...

  2. JSP(java server pages)安装开发和执行环境

    JSP是一种动态网页技术标准. 它是在传统的网页HTML文件中插入Java程序段(Scriptlet)和JSP标记(tag)的.jsp文件: java程序段:操纵数据库,重新定向网页,发送email等 ...

  3. 12. 亿级流量电商系统JVM模型参数二次优化

    亿级流量电商系统JVM模型参数预估方案,在原来的基础上采用ParNew+CMS垃圾收集器 一.亿级流量分析及jvm参数设置 1. 需求分析 大促在即,拥有亿级流量的电商平台开发了一个订单系统,我们应该 ...

  4. 【UE4 C++】 获取Actor、Controller、Pawn、Character

    获取 Actor TActorIterator 遍历 可以用于遍历 Actor,也可以用于遍历 Component for (TActorIterator<AStaticMeshActor> ...

  5. AIApe问答机器人Scrum Meeting 5.3

    Scrum Meeting 6 日期:2021年5月3日 会议主要内容概述:汇报两日工作. 一.进度情况 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 李明昕 后端 与前端对 ...

  6. 主集天线和分集天线——4G天线技术

    主集天线和分集天线 分集接收技术是一项主要的抗衰落技术,可以大大提高多径衰落信道传输下的可靠性,在实际的移动通信系统中,移动台常常工作在城市建筑群或其他复杂的地理环境中,而且移动的速度和方向是任意的. ...

  7. Python课程笔记(十一)

    一.线程与多线程 1.线程与进程 线程指的是 进程(运行中的程序)中单一顺序的执行流. 多个独立执行的线程相加 = 一个进程 多线程程序是指一个程序中包含有多个执行流,多线程是实现并发机制的一种有效手 ...

  8. 精心整理Java微服务最全面试题集(含答案)

    微服务架构相关 大型网站架构演变过程 网站架构演变演变过程 传统架构 → 分布式架构 → SOA架构 → 微服务架构 什么是分布式架构 分布式架构就是将传统结构按照模块进行拆分,不同的人负责不同的模块 ...

  9. [WPF] 使用三种方式实现弧形进度条

    1. 需求 前天看到有人问弧形进度条怎么做,我模仿了一下,成果如下图所示: 当时我第一反应是可以用 Microsoft.Toolkit.Uwp.UI.Controls 里的 RadialGauge 实 ...

  10. WPF_05_路由事件

    路由事件 WPF用更高级的路由事件替换普通的.NET事件.路由事件具有更强传播能力,可在元素树中向上冒泡和向下隧道传播,并沿着传播路径被事件处理程序处理.与依赖属性一样,路由事件由只读的静态字段表示, ...