20180711模拟赛T3——聚变
文件名: fusion
题目类型: 传统题
时间限制: 3秒
内存限制: 256MB
编译优化: 无
题目描述
知名科学家小A在2118年在计算机上实现了模拟聚变的过程。
我们将她研究的过程简化。
核子共有26种,可以用a到z共26个字母表示。
核子聚变的过程可以用一个字符串描述。
按照顺序从左到右的顺序,假如有两个相同核子相邻,两个核子就会相互吸引发生聚变生成一个序号+1的核子,特殊的,两个z核子相邻会湮灭没有新的核子生成。
每当两个核子聚变时,就需要重新从左到右重复找到两个相邻的相同核子直到不存在为止。
比如zyzzy->zyy->zz->
小A为了做出足够有效的实验,每次会从一个字符串中选定一个子串操作。
她想要知道每次实验这个子串中的核子能否最终全部湮灭。
输入格式
第一行一个只有小写字母的字符串。
第二行一个数\(n\)表示询问次数
接下来\(n\)行每行两个正整数\(l_{i},r_{i}\)表示询问区间
输出格式
对每次询问输出一行Yes或No表示答案
样例输入
yzyyyzyzyyyz
8
1 6
7 12
1 12
6 11
1 1
1 3
4 9
3 8
样例输出
Yes
Yes
Yes
Yes
No
No
No
No
数据规模与约定
L表示字符串长度
对于30%的数据满足L<=100
对于60%的数据满足L<=3000,n<=3000
另存在20%数据满足字符串中只存在y,z
对于100%的数据,L<=500000,n<=1000000
题解
开始没看到“从左往右”,还以为是线段树维护分治……
\(nL\)大力60。
我们发现对于一段合法串,我们可以把它分成多个(或一个)连续的合法字串。
比如:
zyyzyyyyz
我们可以分成:
zyy | zyy | yyz
这三段都是合法的,所以原串也是合法的。
又比如说:
zyyyyzyz
我们把它分成:
zyy | yyz | yz
显然,yz是不合法的,所以原串是不合法的。
于是我们检验时,我们可以让指针跳着走:
zyy | yyz | yz
^
zyy | yyz | yz
---->^
zyy | yzz | yz
---->^
zyy | yzz | yz
---->^
发现指针跳到外面去了,所以说是不合法的。
不难想到用一个nxt数组表示以第i个开始的最短合法串末尾的下一个位置(感觉很像kmp)。
那么怎么求nxt呢?
我们需要引入一个to数组。
to[i][j]表示从第i位开始最短能拼成j字符的位置的下一个位置(\(j = 0\sim 26\),\(0\)表示\(a\),\(26\)表示没有)。
不难发现to[i][j] = to[to[i][j-1]][j-1],nxt[i] = to[i][26]。
当然,开始时to与nxt都指向结尾的后面。
然而我们发现这样做会被hack:
xzzxyz
这是因为对于第一个z来讲它只更新了\(25\sim 26\)的情况,所以第一个第一个x的nxt会指向末尾。
所以我们需要排除中间这段zz的干扰。
于是我们又想到转移方程:to[i][j] = to[nxt[i]][j]。
这样就大功告成了。
然而这样做很容易被卡掉,比如说全是z的情况,往后跳的速度会很慢。
所以我们选择倍增。
下面是代码:
#include <cstdio>
#include <cstring>
const int maxn = 500005;
char aa[maxn];
int nxt[maxn][21];
int to[maxn][26];
inline void pre()
{
int len = strlen(aa);
for(int i = 0; i < len; ++i)
aa[i] -= 'a';
for(int i = 0; i < len + 3; ++i)
{
for(int j = 0; j <= 20; ++j)
nxt[i][j] = len + 1;
for(int j = 0; j <= 26; ++j)
to[i][j] = len + 1;
}
for(int i = len - 1; i >= 0; --i)
{
to[i][(int)aa[i]] = i + 1;
for(int j = aa[i] + 1; j <= 26; ++j)
to[i][j] = to[to[i][j-1]][j-1];
nxt[i][0] = to[i][26];
for(int j = 1; j <= 20; ++j)
nxt[i][j] = nxt[nxt[i][j-1]][j-1];
for(int j = 0; j < 26; ++j)
if(to[i][j] == len + 1)
to[i][j] = to[nxt[i][0]][j];
}
}
inline bool pan(int l, int r)
{
l--;
r--; // 从0开始……(感觉自己好作死)
for(int i = 20; i >= 0; --i)
{
if(nxt[l][i] <= r + 1)
l = nxt[l][i];
if(l == r + 1)
return true;
}
return false;
}
int main()
{
freopen("fusion.in", "r", stdin);
freopen("fusion.out", "w", stdout);
gets(aa);
pre();
int n;
scanf("%d", &n);
while(n--)
{
int l, r;
scanf("%d%d", &l, &r);
puts(pan(l, r) ? "Yes" : "No");
}
fclose(stdin);
fclose(stdout);
return 0;
}
20180711模拟赛T3——聚变的更多相关文章
- 体育成绩统计——20180801模拟赛T3
体育成绩统计 / Score 题目描述 正所谓“无体育,不清华”.为了更好地督促同学们进行体育锻炼,更加科学地对同学们进行评价,五道口体校的老师们在体育成绩的考核上可谓是煞费苦心.然而每到学期期末时, ...
- 20180520模拟赛T3——chess
[问题描述] 小美很喜欢下象棋. 而且她特别喜欢象棋中的马. 她觉得马的跳跃方式很独特.(以日字格的方式跳跃) 小芳给了小美一张很大的棋盘,这个棋盘是一个无穷的笛卡尔坐标. 一开始\(time=0\) ...
- 20161005 NOIP 模拟赛 T3 解题报告
subset 3.1 题目描述 一开始你有一个空集,集合可以出现重复元素,然后有 Q 个操作 1. add s 在集合中加入数字 s. 2. del s 在集合中删除数字 s.保证 s 存在 3. c ...
- ztz11的noip模拟赛T3:评分系统
代码: #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> ...
- 4.26 省选模拟赛 T3 状压dp 差分求答案
LINK:T3 比较好的题目 考试的时候被毒瘤的T2给搞的心态爆炸 这道题连正解的思路都没有想到. 一看到题求删除点的最少个 可以使得不连通. 瞬间想到最小割 发现对于10分直接跑最小割即可. 不过想 ...
- NOIP欢乐模拟赛 T3 解题报告
3.小澳的葫芦 (calabash.cpp/c/pas) [题目描述] 小澳最喜欢的歌曲就是<葫芦娃>. 一日表演唱歌,他尽了洪荒之力,唱响心中圣歌. 随之,小澳进入了葫芦世界. 葫芦世界 ...
- 字符串模拟赛T3
只看我的做法就够了 #include<iostream> #include<cstdio> #include<string> #include<cstring ...
- 神奇的NOIP模拟赛 T3 LGTB 玩THD
LGTB 玩THD LGTB 最近在玩一个类似DOTA 的游戏名叫THD有一天他在守一座塔,对面的N 个小兵排成一列从近到远站在塔前面每个小兵有一定的血量hi,杀死后有一定的金钱gi每一秒,他都可以攻 ...
- [模拟赛] T3 Exploit
Description 4X概念体系,是指在PC战略游戏中一种相当普及和成熟的系统概念,得名自4个同样以"EX"为开头的英语单词. eXplore(探索) eXpand(拓张与发展 ...
随机推荐
- 28道java基础面试题-下
28道java基础面试题下 15.Java语言如何进行异常处理,关键字:throws.throw.try.catch.finally分别如何使用? 答:Java通过面向对象的方法进行异常处理,把各种不 ...
- github 入门教程之 github 访问速度太慢怎么办
github 是全世界最流行的开源项目托管平台,其代表的开源文化从根本上改变了软件开发的方式. 基本上所有的需求都能从 github 上或多或少找到现成的实现方案,再也不用重头开始造轮子而是自定义轮子 ...
- sublime3配置
1.sunblim3配置 一旦配置好了,如果换了一台电脑那直接将C:\Users\djx\AppData\Roaming\Sublime Text 3\Packages\User文件夹拷贝到新下载的s ...
- 怎样把ndarray转换为PyQt中的QPixmap
找不到文档,只在网上找到一些语焉不详,执行错误的代码,鼓捣了一个晚上,研(luan)究(gao)成功 def img2pixmap(self, image): Y, X = image.shape[: ...
- 洛谷P3455 [POI2007]ZAP-Queries
题目大意: 给定\(n,m,k,\) 求 \[\sum\limits_{x=1}^n\sum\limits_{y=1}^m[gcd(x,y)==k]\] 莫比乌斯反演入门题,先进行一步转化,将每个\( ...
- nuxtjs踩坑指南
1.nuxt引入问题:Can't resolve 'stylus-loader' 原因在于没有安装stylus,安装即可:npm install stylus stylus-loader --save ...
- guava(四)区间Ranges
一.构建区间 (a..b) open(C, C) [a..b] closed(C, C) [a..b) closedOpen(C, C) (a..b] openClosed(C, C) (a..+∞) ...
- es6的map()方法解释
es6的map()方法解释 map方法的作用不难理解,即“映射”,也就是原数组被“映射”成对应新数组.下面这个例子是数值项求平方: var data = [1, 2, 3, 4]; var arr ...
- 初探云原生应用管理(一): Helm 与 App Hub
系列介绍:初探云原生应用管理系列是介绍如何用云原生技术来构建.测试.部署.和管理应用的内容专辑.做这个系列的初衷是为了推广云原生应用管理的最佳实践,以及传播开源标准和知识.通过这个系列,希望帮 ...
- 如何当上Leader和六千个bug的系统
在昨天的读书会上我分享了我是如何当上leader以及当上leader之后的体会.然后今天Sophie总结了我的发言,大家对此有些反馈.我根据大家的反馈写了这篇文章,主要针对几点: 大家如何当上lead ...