【字符串哈希】bzoj3916 [Baltic2014]friends
枚举断点,哈希判断。
#include<cstdio>
using namespace std;
typedef unsigned long long ull;
ull hs,hs1,hs2,seeds[1000010],hsgoal;
int n;
int del=-1;
char s[2000002],s2[2000002];
int main()
{
seeds[0]=1;
for(int i=1;i<=1000009;++i) seeds[i]=seeds[i-1]*31;
scanf("%d%s",&n,s);
if(!(n&1)) {puts("NOT POSSIBLE"); return 0;}
for(int i=(n>>1)+1;i<n;++i)
hs=hs*31+(s[i]-64);
for(int i=1;i<=(n>>1);++i)
hs2=hs2*31+(s[i]-64);
if(hs2==hs)
{
del=0;
hsgoal=hs;
}
for(int i=1;i<=(n>>1);++i)
{
hs2-=((s[i]-64)*seeds[(n>>1)-i]);
hs1=hs1*31+(s[i-1]-64);
if(hs1*seeds[(n>>1)-i]+hs2==hs)
{
if(del!=-1&&hsgoal!=hs)
{
puts("NOT UNIQUE");
return 0;
}
else
{
del=i;
hsgoal=hs;
}
}
}
hs=hs1=hs2=0;
for(int i=0;i<(n>>1);++i)
hs=hs*31+(s[i]-64);
for(int i=(n>>1)+1;i<n;++i)
hs2=hs2*31+(s[i]-64);
for(int i=(n>>1)+1;i<n;++i)
{
hs2-=((s[i]-64)*seeds[n-1-i]);
hs1=hs1*31+(s[i-1]-64);
if(hs1*seeds[n-1-i]+hs2==hs)
{
if(del!=-1&&hsgoal!=hs)
{
puts("NOT UNIQUE");
return 0;
}
else
{
del=i;
hsgoal=hs;
}
}
}
if(del==-1)
puts("NOT POSSIBLE");
else if(del<=(n>>1))
{
for(int i=0;i<=(n>>1);++i)
if(i!=del)
putchar(s[i]);
puts("");
}
else
{
for(int i=(n>>1);i<n;++i)
if(i!=del)
putchar(s[i]);
puts("");
}
return 0;
}
【字符串哈希】bzoj3916 [Baltic2014]friends的更多相关文章
- HDU 1880 魔咒词典(字符串哈希)
题目链接 Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一 ...
- 洛谷P3370 【模板】字符串哈希
P3370 [模板]字符串哈希 143通过 483提交 题目提供者HansBug 标签 难度普及- 提交 讨论 题解 最新讨论 看不出来,这题哪里是哈希了- 题目描述 如题,给定N个字符串(第i个 ...
- HDU2594 Simpsons’ Hidden Talents 字符串哈希
最近在学习字符串的知识,在字符串上我跟大一的时候是没什么区别的,所以恶补了很多基础的算法,今天补了一下字符串哈希,看的是大一新生的课件学的,以前觉得字符串哈希无非就是跟普通的哈希没什么区别,倒也没觉得 ...
- LA 6047 Perfect Matching 字符串哈希
一开始我用的Trie+计数,但是不是计多了就是计少了,后来暴力暴过去的…… 看了别人的代码知道是字符串哈希,但是仍有几个地方不理解: 1.26^500溢出问题 2.没考虑哈希碰撞? 跪求指点! #in ...
- AC日记——【模板】字符串哈希 洛谷 3370
题目描述 如题,给定N个字符串(第i个字符串长度为Mi,字符串内包含数字.大小写字母,大小写敏感),请求出N个字符串中共有多少个不同的字符串. 友情提醒:如果真的想好好练习哈希的话,请自觉,否则请右转 ...
- 从Hash Killer I、II、III论字符串哈希
首先,Hash Killer I.II.III是BZOJ上面三道很经典的字符串哈希破解题.当时关于II,本人还琢磨了好久,但一直不明白为啥别人AC的代码都才0.3kb左右,直到CYG神犇说可以直接随机 ...
- 【NOIP模拟】Grid(字符串哈希)
题目背景 SOURCE:NOIP2016-RZZ-1 T3 题目描述 有一个 2×N 的矩阵,矩阵的每个位置上都是一个英文小写字符. 现在需要从某一个位置开始,每次可以移动到一个没有到过的相邻位置,即 ...
- 洛谷 P3370 【模板】字符串哈希
洛谷 P3370 [模板]字符串哈希 题目描述 如题,给定N个字符串(第i个字符串长度为Mi,字符串内包含数字.大小写字母,大小写敏感),请求出N个字符串中共有多少个不同的字符串. 友情提醒:如果真的 ...
- cf_514C(字符串哈希)
题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=121897#problem/G Watto and Mechanism Time ...
- 洛谷 P3370 字符串哈希 (模板)
<题目链接> <转载于 >>> > 题目描述 如题,给定N个字符串(第i个字符串长度为Mi,字符串内包含数字.大小写字母,大小写敏感),请求出N个字符串中共 ...
随机推荐
- Spring AOP execution表达式
Spring中事务控制相关配置: <bean id="txManager" class="org.springframework.jdbc.datasource.D ...
- SICAU-OJ: 第k小
第k小 题意: 给出一个长度不超过5000的字符串,然后让你找出第K小的字串(1<=K<=5).重复的串大小相等. 题解: 这里我们知道某些串的前缀是肯定小于等于其本身的. 那么长度为5的 ...
- nodejs npm insttall 带不带-g这个参数的区别
-g 中的g是global的意思所以带-g这个参数是全局安装,不带-g这个参数是本地安装. 在windows系统中全局安装的目录在:C:\Users\linsenq\AppData\Roaming\n ...
- (转)tableview的索引设置
.感觉tableview的索引条将表视图往左边挤了一点?别担心,只是颜色问题.只要如此设置即可 //索引条背景的颜色(清空颜色就不会感觉索引条将tableview往左边挤) [_tableView s ...
- springmvc4+hibernate4+activiti5.18(Maven)
项目下载地址: http://files.cnblogs.com/files/walk-the-Line/springmvc_activiti5.18_hibernate4.zip
- Ubuntu下修改NAT模式的IP地址
1,查看虚拟机的网段 在编辑->虚拟网络编辑器->NAT设置->网关 IP 可以查看到虚拟机的网关 如图 2,图形化设置: 图中 Netmask设置的是255.255.255.0 ...
- Flink源码阅读(一)--Checkpoint触发机制
Checkpoint触发机制 Flink的checkpoint是通过定时器周期性触发的.checkpoint触发最关键的类是CheckpointCoordinator,称它为检查点协调器. org.a ...
- 【eclipse使用git】eclipse使用私钥提交项目
初次安装git需要配置用户名和邮箱,否则git会提示:please tell me who you are. 你需要运行命令来配置你的用户名和邮箱: $ git config --global use ...
- python收集
http://my.oschina.net/mutour/blog/?disp=2&catalog=0&sort=time&p=4 Python 不使用win32api打开任务 ...
- mysql导入数据库出现:Incorrect string value: '\xE7\x82\xB9\xE9\x92\x9F' for column 'chinese' at row 1
mysql导入数据库出现:Incorrect string value: '\xE7\x82\xB9\xE9\x92\x9F' for column 'chinese' at row 1 使用 sho ...