@atcoder - ARC077F@ SS
@description@
规定一个字符串为 “偶串” 当且仅当它可以表示成两个相同的字符串连接(如 "xyzxyz" 或 "aaaaaa")。
给定一个仅由小写字母组成的初始偶串 \(S_0\)。我们可以通过在 \(S_i\) 后加最少的字符(至少一个字符)得到新的偶串 \(S_{i+1}\),不难发现 \(S_{i+1}\) 是唯一存在的。
求在 \(S_{10^{100}}\) 中第 l 个字符到第 r 个字符中每个小写字母的出现次数。
@solution@
考虑一个偶串 \(TT\) 怎么加最少的字符成为新的偶串 \(T'T'\):找到 \(T\) 的最大 border \(P\) 与最小周期 \(Q\),将 \(T\) 写作 \(Q + P\),则 \(T' = Q + P + Q\)。
我们考虑已知 \(T\) 怎么快速求 \(T'\) 的最大 border:
如果 \(T\) 是循环串,则 \(T'\) 也是循环串,因此 \(T'\) 的最大 border 长度 = \(|T'| - |Q|\)。
否则,\(T'\) 的最大 border 长度为 \(|Q|\)。
关于第二条结论,首先注意到 \(T'\) 的最大 border 长度 \(\leq |P| + |Q|\) 且 \(\geq |Q|\)。
画一画发现假如 \(T'\) 的最大 border 长度为 L,则 \(T\) 中长度为 L 的前缀存在长度为 \(|Q|\) 的 border,根据弱周期引理可推出矛盾。
关于实现,前一种太简单了不讲;后一种可以发现 \(T_i\) 是 \(T_{i-1}\) 与 \(T_{i-2}\) 的拼接,长度呈斐波那契数列增长(跟指数级差不多),因此递归求解即可。
然后发现前一种情况可以直接用后一种情况的写法,减少代码量。
@accepted code@
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
typedef long long ll;
const int MAXN = 200000;
ll a[26], b[26], c[150][26], d[150];
char S[MAXN + 5]; int f[MAXN + 5];
int main() {
int n, m; ll l, r;
scanf("%s%lld%lld", S + 1, &l, &r);
n = strlen(S + 1), m = n / 2;
f[0] = -1, f[1] = 0;
for(int i=2;i<=m;i++) {
int j = f[i - 1];
while( j != -1 && S[i] != S[j + 1] )
j = f[j];
f[i] = j + 1;
}
int p = m - f[m];
for(int i=1;i<=p;i++) c[0][S[i] - 'a']++;
for(int i=1;i<=m;i++) c[1][S[i] - 'a']++;
int k; d[0] = p, d[1] = m;
for(k=1;d[k]<=r;k++) {
for(int j=0;j<26;j++)
c[k + 1][j] = c[k][j] + c[k - 1][j];
d[k + 1] = d[k] + d[k - 1];
}
ll t = r;
for(int i=k;i>=0;i--) {
if( t >= d[i] ) {
for(int j=0;j<26;j++)
a[j] += c[i][j];
t -= d[i];
}
}
for(int i=1;i<=t;i++)
a[S[i] - 'a']++;
t = l - 1;
for(int i=k;i>=0;i--) {
if( t >= d[i] ) {
for(int j=0;j<26;j++)
a[j] -= c[i][j];
t -= d[i];
}
}
for(int i=1;i<=t;i++)
a[S[i] - 'a']--;
for(int i=0;i<26;i++) printf("%lld ", a[i]);
}
@details@
当然关于实现,递推也可以,而且写起来也比较简单。
@atcoder - ARC077F@ SS的更多相关文章
- AtCoder刷题记录
构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...
- 【arc077f】AtCoder Regular Contest 077 F - SS
题意 给你一个形如"SS"的串S,以及一个函数\(f(x)\),\(x\)是一个形如"SS"的字符串,\(f(x)\)也是一个形如"SS"的 ...
- AtCoder Beginner Contest 066 B - ss
题目链接:http://abc066.contest.atcoder.jp/tasks/abc066_b Time limit : 2sec / Memory limit : 256MB Score ...
- 【ARC077F】SS
Description 如果某个串可以由两个一样的串前后连接得到,我们就称之为"偶串".比如说"xyzxyz"和"aaaaaa"是偶串,而& ...
- 【ARC077F】SS kmp+打表找规律
Description 如果某个串可以由两个一样的串前后连接得到,我们就称之为"偶串".比如说"xyzxyz"和"aaaaaa"是偶串, ...
- 【arc077f】AtCoder Regular Contest 074 F - Lotus Leaves
题意 给定一个n*m的池塘,每个格子上可能有叶子. 从一个叶子出发,可以跳到相同行或相同列的叶子. 问至少去掉多少叶子,使得起点不能到达终点. \(n,m<=100\) 解法 很显然的最小割模型 ...
- AtCoder Grand Contest 008
AtCoder Grand Contest 008 A - Simple Calculator 翻译 有一个计算器,上面有一个显示按钮和两个其他的按钮.初始时,计算器上显示的数字是\(x\),现在想把 ...
- 【atcoder F - Namori】**
F- Namori http://agc004.contest.atcoder.jp/tasks/agc004_f Time limit : 2sec / Memory limit : 256MB S ...
- AtCoder Regular Contest 093
AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...
随机推荐
- iperf压测linux网卡带宽
1.安装 yum install iperf --enablerepo=epel 2.启动服务端 iperf -s -i 1 3.启动客户端测试10分钟 iperf -c 172.16.3.153 - ...
- LibreOJ #515 贪心只能过样例
题目链接:https://loj.ac/problem/515 知识点: DP.bitset类 解题思路: DP部分不难想到:从 a 到 b 遍历,然后在已有的状态上加上遍历得到的数字的平方,难点在于 ...
- 玩转java反射
玩玩JAVA反射 什么是反射 Java反射机制是在运行状态中,对于任意一个类,都能知道这个类的所有属性和方法:对于任何一个对象,都能够调用它的任何一个方法和属性:这样动态获取新的以及动态调用对象的方法 ...
- js常用 方法 封装
// 监听滚动,用于列表页向下加载--------------------------------- function loadmore(callback) { $(window).scroll(fu ...
- 3.key的操作
我们之前使用Redis简单存储了三个参数: 在语句set name jack中,其中name就是一个key.我们Java中的变量名是有一定规则的,比如组成内容可以是“数字”,“字母”以及“下划线”. ...
- React-Native 爬坑爬坑
出现函数找不到问题一般都是this的指向问题,一般是用箭头函数解决,解决不了就传入this 在setState里面一定不能要直接写state引入的值,如: this.setState({now: th ...
- DataFrame的apply用法
DataFrame的apply方法: def cal_value_percent(row,total_value): row['new_column']=row[estimated_value_col ...
- jchdl - GSL实例 - MulC2(有符号数的乘法)
这里的实现,先把符号位取出来,使用两个正数相乘,然后在把符号加到乘积上. 参考链接 https://github.com/wjcdx/jchdl/blob/master/src/org/jch ...
- (String),toString(),String.valueOf()
String.valueOf("")的源码:(推荐这种写法) 注意:obj问null时,返回值是字符串"null" toString("") ...
- 腾讯云EMR大数据实时OLAP分析案例解析
OLAP(On-Line Analytical Processing),是数据仓库系统的主要应用形式,帮助分析人员多角度分析数据,挖掘数据价值.本文基于QQ音乐海量大数据实时分析场景,通过QQ音乐与腾 ...