Luogu P4503 [CTSC2014]企鹅QQ(字符串哈希)
题面
题目背景
\(PenguinQQ\) 是中国最大、最具影响力的 \(SNS(Social Networking Services)\) 网站,以实名制为基础,为用户提供日志、群、即时通讯、相册、集市等丰富强大的互联网功能体验,满足用户对社交、资讯、娱乐、交易等多方面的需求。
题目描述
小 \(Q\) 是 \(PenguinQQ\) 网站的管理员,他最近在进行一项有趣的研究——哪些账户是同一个人注册的。经过长时间的分析,小 \(Q\) 发现同一个人注册的账户名称总是很相似的,例如 \(Penguin1, Penguin2, Penguin3……\) 于是小 \(Q\) 决定先对这种相似的情形进行统计。
小 \(Q\) 定义,若两个账户名称是相似的,当且仅当这两个字符串等长且恰好只有一位不同。例如 \(“Penguin1”\) 和 \(“Penguin2”\) 是相似的,但 \(“Penguin1”\) 和 \(“2Penguin”\) 不是相似的。而小 \(Q\) 想知道,在给定的 \(n\) 个账户名称中,有多少对是相似的。
为了简化你的工作,小 \(Q\) 给你的 \(N\) 个字符串长度均等于 \(L\) ,且只包含大小写字母、数字、下划线以及 \('@'\) 共 \(64\) 种字符,而且不存在两个相同的账户名称。
输入输出格式
输入格式:
第一行包含三个正整数 \(N, L, S\) 。其中 \(N\) 表示账户名称数量, \(L\) 表示账户名称长度, \(S\) 用来表示字符集规模大小,它的值只可能为 \(2\) 或 \(64\) 。
若 \(S\) 等于 \(2\) ,账户名称中只包含字符 \(‘0’\) 和 \(‘1’\) 共 \(2\) 种字符;
若 \(S\) 等于 \(64\) ,账户名称中可能包含大小写字母、数字、下划线以及 \('@'\) 共 \(64\) 种字符。
随后 \(N\) 行,每行一个长度为 \(L\) 的字符串,用来描述一个账户名称。数据保证 \(N\) 个字符串是两两不同的。
输出格式:
仅一行一个正整数,表示共有多少对相似的账户名称。
输入输出样例
输入样例:
4 3 64
Fax
fax
max
mac
输出样例:
4
说明
\(4\) 对相似的字符串分别为: \(Fax\) 与 \(fax\) , \(Fax\) 与 \(max\) , \(fax\) 与 \(max\) , \(max\) 与 \(mac\) 。
| 测试点编号 | N | L | S |
|---|---|---|---|
| 1 | 50 | 10 | 64 |
| 2 | 500 | 100 | 64 |
| 3 | 3000 | 100 | 2 |
| 4 | 3000 | 100 | 64 |
| 5 | 30000 | 50 | 2 |
| 6 | 30000 | 50 | 64 |
| 7 | 30000 | 200 | 2 |
| 8 | 30000 | 200 | 64 |
| 9 | 30000 | 200 | 2 |
| 10 | 30000 | 200 | 64 |
思路
\(Hash\) 是真的强,比 \(kmp\) 好玩多了。 --Uranus
那肯定啦。 --alecli
这是一道字符串哈希的题。考虑如果题目问的不是“相似字符串”而是“相同字符串”,那么可以直接用字符串哈希来解决这一问题。而既然所有字符串的长度相同,考虑枚举相似字符串的不同位,把它去掉,然后比较剩下的字符串是否相同就好了。
利用字符串哈希的话,只需要求一遍所有字符串前缀的哈希值,再反着跑一遍,求后缀的哈希值,每次合并前缀和后缀就好了。
AC代码
#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ULL;
const ULL Pa=131;
const ULL Pb=137;
ULL n,l,s,ans,aHash[30005][205],bHash[30005][205],tmp[30005];
string str;
int main()
{
cin>>n>>l>>s;
for(ULL i=0;i<n;i++)
{
cin>>str;
str='0'+str;
for(ULL j=1;j<=l;j++) aHash[i][j]=aHash[i][j-1]*Pa+str[j];
for(ULL j=l;j;j--) bHash[i][j]=bHash[i][j+1]*Pb+str[j];
}
for(ULL i=1;i<=l;i++)
{
for(ULL j=0;j<n;j++) tmp[j]=aHash[j][i-1]*139+bHash[j][i+1]*149;
sort(tmp,tmp+n);
int now=0;
for(ULL j=0;j<n-1;j++)
if(tmp[j]==tmp[j+1]) ans+=(++now);
else now=0;
}
cout<<ans;
return 0;
}
Luogu P4503 [CTSC2014]企鹅QQ(字符串哈希)的更多相关文章
- BZOJ 3555: [Ctsc2014]企鹅QQ [字符串哈希]【学习笔记】
3555: [Ctsc2014]企鹅QQ Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 2046 Solved: 749[Submit][Statu ...
- bzoj3555 [Ctsc2014]企鹅QQ——字符串哈希
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3555 很久以前就讲过哈希,但一直没写过题,所以这是哈希第一题! 哈希就是把一个字符串映射成一 ...
- Luogu P4503 [CTSC2014]企鹅QQ
思路 如果直接暴力的比较的话,不用想也知道会超时 所以考虑另一种方法,将前缀和的思想运用到hash中.用两个hash,一个从前往后记录,一个从后往前记录,然后枚举哪一位是不相同的,然后删掉这一位,将这 ...
- 【题解】P4503 [CTSC2014]企鹅QQ(哈希)
[题解]P4503 [CTSC2014]企鹅QQ(哈希) 考虑这样一种做法,将每个字符串的删去某个字符的新字符串的哈希值存下来,然后最后\(sort\)一遍双指针统计每个值相同的数的个数\(x\),这 ...
- 洛谷 P4503 [CTSC2014]企鹅QQ 解题报告
P4503 [CTSC2014]企鹅QQ 题目背景 PenguinQQ是中国最大.最具影响力的SNS(Social Networking Services)网站,以实名制为基础,为用户提供日志.群.即 ...
- 字符串Hash || BZOJ 3555: [Ctsc2014]企鹅QQ || P4503 [CTSC2014]企鹅QQ
题面:[CTSC2014]企鹅QQ 题解:无 代码: #include<iostream> #include<cstring> #include<cstdio> # ...
- 洛谷$P4503\ [CTSC2014]$企鹅$QQ$ 哈希
正解:哈希 解题报告: 传送门$QwQ$ 直接$O(len)$枚举哪一位,然后把这一位删了重新拼接起来,存桶里查下就成 $over$? 主要的难点大概在卡哈希+卡常$QAQ$ #include< ...
- 【BZOJ 3555】 [Ctsc2014]企鹅QQ(哈希)
Description PenguinQQ是中国最大.最具影响力的SNS(Social Networking Services)网站,以实名制为基础,为用户提供日志.群.即时通讯.相册.集市等丰富强大 ...
- 【bzoj3555】[Ctsc2014]企鹅QQ 简单哈希
传送门 题目分析 题意即求有多少对字符串只相差一个字符,枚举删除每个字符后的哈希, 看有多少相等即可. 比如有如下字符串:$Sd123$,其中S部分的哈希值为H,删除的是d,则原字符串的哈希值为$$( ...
随机推荐
- <前端>简单实现开心网注册
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- C#の单例模式
版本一: /// <summary>/// A simple singleton class implements./// </summary>public sealed cl ...
- 打开新窗口(window.open) open() 方法可以查找一个已经存在或者新建的浏览器窗口。 语法: window.open([URL], [窗口名称], [参数字符串])
打开新窗口(window.open) open() 方法可以查找一个已经存在或者新建的浏览器窗口. 语法: window.open([URL], [窗口名称], [参数字符串]) 参数说明: URL: ...
- Codeigniter 获取当前的控制器名称和方法名称
在Codeigniter 可以通过下面两个方法获取当前的控制器名称和方法名称 $this->router->fetch_class(); $this->router->fetc ...
- Ubuntu Service说明与使用方法
1 什么是Ubuntu的Service 网上很多资料说, service就是linux中随开机自启动的, 并且在后台运行的程序. 个人认为, 至少对于Ubuntu来说, 这个说法是不太准确的, 这只不 ...
- leetcode-142-环形链表②
题目描述: 方法一:O(n) O(n) # Definition for singly-linked list. # class ListNode(object): # def __init__(se ...
- 廖雪峰Java14Java操作XML和JSON-2JSON-1Json介绍
JSON是一种类似JavaScript对象的数据表示格式 JavaScript Object Notation 去除了JavaScript的执行语句 仅保留数据 JSON格式: 仅保留UTF-8编码 ...
- GROUP方法也是连贯操作方法之一
GROUP方法也是连贯操作方法之一,通常用于结合合计函数,根据一个或多个列对结果集进行分组 . group方法只有一个参数,并且只能使用字符串. 例如,我们都查询结果按照用户id进行分组统计: $th ...
- 连通图,set——cf1037E
看了题解又调了很久,用set来维护当前满足条件的pair<degree[v],v> 离线操作,先建好一张图,然后建立好集合,每次删边后都把集合里不满足条件的点删去,同时更新集合 /* 离线 ...
- mysql 一次性插入的数据量过大报错max_allowed_packet解决方法
查询: show VARIABLES like ‘%max_allowed_packet%‘; 记录下数字(默认是一个7位) 执行语句: ; 重启服务 再查询 该数字 ,如果没变,则修改mysql的m ...