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\) 个字符串是两两不同的。

输出格式:

仅一行一个正整数,表示共有多少对相似的账户名称。

输入输出样例

输入样例:

  1. 4 3 64
  2. Fax
  3. fax
  4. max
  5. mac

输出样例:

  1. 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代码

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. typedef unsigned long long ULL;
  4. const ULL Pa=131;
  5. const ULL Pb=137;
  6. ULL n,l,s,ans,aHash[30005][205],bHash[30005][205],tmp[30005];
  7. string str;
  8. int main()
  9. {
  10. cin>>n>>l>>s;
  11. for(ULL i=0;i<n;i++)
  12. {
  13. cin>>str;
  14. str='0'+str;
  15. for(ULL j=1;j<=l;j++) aHash[i][j]=aHash[i][j-1]*Pa+str[j];
  16. for(ULL j=l;j;j--) bHash[i][j]=bHash[i][j+1]*Pb+str[j];
  17. }
  18. for(ULL i=1;i<=l;i++)
  19. {
  20. for(ULL j=0;j<n;j++) tmp[j]=aHash[j][i-1]*139+bHash[j][i+1]*149;
  21. sort(tmp,tmp+n);
  22. int now=0;
  23. for(ULL j=0;j<n-1;j++)
  24. if(tmp[j]==tmp[j+1]) ans+=(++now);
  25. else now=0;
  26. }
  27. cout<<ans;
  28. return 0;
  29. }

Luogu P4503 [CTSC2014]企鹅QQ(字符串哈希)的更多相关文章

  1. BZOJ 3555: [Ctsc2014]企鹅QQ [字符串哈希]【学习笔记】

    3555: [Ctsc2014]企鹅QQ Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 2046  Solved: 749[Submit][Statu ...

  2. bzoj3555 [Ctsc2014]企鹅QQ——字符串哈希

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3555 很久以前就讲过哈希,但一直没写过题,所以这是哈希第一题! 哈希就是把一个字符串映射成一 ...

  3. Luogu P4503 [CTSC2014]企鹅QQ

    思路 如果直接暴力的比较的话,不用想也知道会超时 所以考虑另一种方法,将前缀和的思想运用到hash中.用两个hash,一个从前往后记录,一个从后往前记录,然后枚举哪一位是不相同的,然后删掉这一位,将这 ...

  4. 【题解】P4503 [CTSC2014]企鹅QQ(哈希)

    [题解]P4503 [CTSC2014]企鹅QQ(哈希) 考虑这样一种做法,将每个字符串的删去某个字符的新字符串的哈希值存下来,然后最后\(sort\)一遍双指针统计每个值相同的数的个数\(x\),这 ...

  5. 洛谷 P4503 [CTSC2014]企鹅QQ 解题报告

    P4503 [CTSC2014]企鹅QQ 题目背景 PenguinQQ是中国最大.最具影响力的SNS(Social Networking Services)网站,以实名制为基础,为用户提供日志.群.即 ...

  6. 字符串Hash || BZOJ 3555: [Ctsc2014]企鹅QQ || P4503 [CTSC2014]企鹅QQ

    题面:[CTSC2014]企鹅QQ 题解:无 代码: #include<iostream> #include<cstring> #include<cstdio> # ...

  7. 洛谷$P4503\ [CTSC2014]$企鹅$QQ$ 哈希

    正解:哈希 解题报告: 传送门$QwQ$ 直接$O(len)$枚举哪一位,然后把这一位删了重新拼接起来,存桶里查下就成 $over$? 主要的难点大概在卡哈希+卡常$QAQ$ #include< ...

  8. 【BZOJ 3555】 [Ctsc2014]企鹅QQ(哈希)

    Description PenguinQQ是中国最大.最具影响力的SNS(Social Networking Services)网站,以实名制为基础,为用户提供日志.群.即时通讯.相册.集市等丰富强大 ...

  9. 【bzoj3555】[Ctsc2014]企鹅QQ 简单哈希

    传送门 题目分析 题意即求有多少对字符串只相差一个字符,枚举删除每个字符后的哈希, 看有多少相等即可. 比如有如下字符串:$Sd123$,其中S部分的哈希值为H,删除的是d,则原字符串的哈希值为$$( ...

随机推荐

  1. 面试系列22 dubbo的工作原理

    (1)dubbo工作原理 第一层:service层,接口层,给服务提供者和消费者来实现的 第二层:config层,配置层,主要是对dubbo进行各种配置的 第三层:proxy层,服务代理层,透明生成客 ...

  2. SwiftUI 实现Draggesture效果

    今天闲来无事,使用SwiftUI 实现拖动,并且返回的动态效果.代码不多..... 效果如下: 代码如下: import SwiftUI import Combine class KBDragObje ...

  3. php实现在不同国家显示网站的不同语言版本

    首先,你的网站本身要拥有多个语言版本.不然的话你就只能用JS去转化了. 1.通过ip去定位,这个要引用到第三方的接口进行数据的完整返回,但是不知道是我的网速太慢还是什么原因,个人觉得这个方法会卡顿: ...

  4. python+selenium中webdriver相关资源

    Chrome chrome的webdriver :  http://chromedriver.storage.googleapis.com/index.html chrome的webdriver需要对 ...

  5. 一.ES6的开发环境搭建

    前言: 现在的Chrome浏览器已经支持ES6了,但是有些低版本的浏览器还是不支持ES6的语法,这就需要我们把ES6的语法自动的转变成ES5的语法.Webpack是有自动编译转换能力的,除了Webpa ...

  6. Ionic3 demo TallyBook 实例2

    1.添加插件 2.相关页面 消费页面: <ion-header> <ion-navbar> <ion-title> 消费记录 </ion-title> ...

  7. 洛谷 NOIP提高组模拟赛 Day1

    传送门 ## $T1$ 一道结论题,设原来A队能力最大的是x,那么A队的选择方案就是$2^{x-1}$,B队的选择方案就是$(2^{n-x}-1)$种,因为不能不选.其中$1\leq x\leq n$ ...

  8. JeecgBoot 2.1.1 代码生成器AI版本发布,基于SpringBoot+AntDesign的JAVA快速开发平台

    此版本重点升级了 Online 代码生成器,支持更多的控件生成,所见即所得,极大的提高开发效率:同时做了数据库兼容专项工作,让 Online 开发兼容更多数据库:Mysql.SqlServer.Ora ...

  9. SpringBoot 03_利用FastJson返回Json数据

    自上一节:SpringBoot 02_返回json数据,可以返回json数据之后,由于有些人习惯于不同的Json框架,比如fastjson,这里介绍一下如何在SpringBoot中集成fastjson ...

  10. [原创]新版PageOffice V4.0为什么用弹出窗口的方式打开文件?

    前的包含文档处理功能的Web办公系统,在打开文档的时候,一部分系统是采用Office文档嵌入到主窗口页面中右侧工作区域的方式,另一部分系统采用的是弹出新的浏览器窗口,里面完整的嵌入Office文件的打 ...