再次膜拜此强题!神级性质之不可能发现系列收藏++;首先,对于长度<=3的情况,我们采取爆搜答案(代码当中是打表)。对于长度>=4的情况,则有如下几条玄妙的性质:

  首先我们将 a, b, c 三个字母看做 0, 1, 2。发现(不知道怎么发现的)当我们做出一次变换之后,数列的和在模意义下是不改变的。(*启示:很多关系好像都和取模之后的某些东西有关,例如食物链,此题,and so on)。

  那么:当一个序列 T 可以由 S 转化过来时,T必须满足如下几条性质:

  1.T的各位字母之和与S的各位字母之和在 %3 的意义下相等。

  2.T中必须存在有两个相邻的相同字母(如果不是,不可能是变换后的结果)

  当以上两条性质都不满足时,还剩下一种情况,即 S = T。

  如何证明是对的?题解如是说:当 n = 4 时,我们可以用打表来验证此性质。当 n > 4 时,我们可以让第一个字母通过变换变成一样的,然后就变成了两个 n - 1 的序列。这样递归下去,当递归到 4 时,即可得证。看起来好像很对的样子,然而怎么证明一定可以把第一个字母变成一样的呢?我并不会……

  建立状态 f[i][j][k][p] 表示 dp 到第 i 位,前面的和在模意义下为 j ,最后一位是 k ,是否已经有两个相邻的相同字母的方案数。然后枚举一下,转移就可以惹……

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define maxn 200050
#define mod 998244353
int n, ans, f[maxn][][][], sum;
char a[maxn]; int read()
{
int x = , k = ;
char c; c = getchar();
while(c < '' || c > '') { if(c == '-') k = -; }
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * k;
} bool Check()
{
for(int i = ; i <= n; i ++)
if(a[i] != a[i - ]) return ;
return ;
} bool Check2()
{
for(int i = ; i <= n; i ++)
if(a[i] == a[i - ]) return ;
return ;
} void Up(int &x, int y) { x = (x + y) % mod; }
void DP(int i, int j, int k, int p)
{
for(int q = ; q <= ; q ++)
Up(f[i + ][q][(q + k) % ][p | (j == q)], f[i][j][k][p]);
} signed main()
{
scanf("%s", a + ); n = strlen(a + );
if(Check()) { puts(""); return ; }
if(n <= )
{
if(n == ) puts("");
else
{
if(a[] != a[] && a[] != a[] && a[] != a[]) puts("");
else if(a[] == a[]) puts("");
else puts("");
}
return ;
}
for(int i = ; i <= n; i ++) sum = (sum + a[i] - 'a') % ;
for(int i = ; i <= ; i ++) f[][i][i][] = ;
for(int i = ; i <= n - ; i ++)
for(int j = ; j <= ; j ++)
for(int k = ; k <= ; k ++)
for(int p = ; p <= ; p ++)
DP(i, j, k, p);
for(int i = ; i <= ; i ++) Up(ans, f[n][i][sum][]);
Up(ans, Check2());
printf("%lld\n", ans);
return ;
}

【题解】Atcoder ARC#94 F-Normalization的更多相关文章

  1. 【题解】 AtCoder ARC 076 F - Exhausted? (霍尔定理+线段树)

    题面 题目大意: 给你\(m\)张椅子,排成一行,告诉你\(n\)个人,每个人可以坐的座位为\([1,l]\bigcup[r,m]\),为了让所有人坐下,问至少还要加多少张椅子. Solution: ...

  2. [题解] Atcoder ARC 142 D Deterministic Placing 结论,DP

    题目 (可能有点长,但是请耐心看完,个人认为比官方题解好懂:P) 首先需要注意,对于任意节点i上的一个棋子,如果在一种走法中它走到了节点j,另一种走法中它走到了节点k,那么这两种走法进行完后,棋子占据 ...

  3. [题解] Atcoder ARC 142 E Pairing Wizards 最小割

    题目 建图很妙,不会. 考虑每一对要求合法的巫师(x,y),他们两个的\(a\)必须都大于\(min(b_x,b_y)\).所以在输入的时候,如果\(a_x\)或者\(a_y\)小于\(min(b_x ...

  4. [题解] Atcoder AGC 005 F Many Easy Problems NTT,组合数学

    题目 观察当k固定时答案是什么.先假设每个节点对答案的贡献都是\(\binom{n}{k}\),然后再减掉某个点没有贡献的选点方案数.对于一个节点i,它没有贡献的方案数显然就是所有k个节点都选在i连出 ...

  5. [atcoder contest 010] F - Tree Game

    [atcoder contest 010] F - Tree Game Time limit : 2sec / Memory limit : 256MB Score : 1600 points Pro ...

  6. [题解] Atcoder Regular Contest ARC 147 A B C D E 题解

    点我看题 A - Max Mod Min 非常诈骗.一开始以为要观察什么神奇的性质,后来发现直接模拟就行了.可以证明总操作次数是\(O(nlog a_i)\)的.具体就是,每次操作都会有一个数a被b取 ...

  7. 【题解】Atcoder ARC#90 F-Number of Digits

    Atcoder刷不动的每日一题... 首先注意到一个事实:随着 \(l, r\) 的增大,\(f(r) - f(l)\) 会越来越小.考虑暴力处理出小数据的情况,我们可以发现对于左端点 \(f(l) ...

  8. 【Atcoder】ARC 080 F - Prime Flip

    [算法]数论,二分图最大匹配 [题意]有无限张牌,给定n张面朝上的牌的坐标(N<=100),其它牌面朝下,每次操作可以选定一个>=3的素数p,并翻转连续p张牌,求最少操作次数使所有牌向下. ...

  9. [题解] Atcoder Regular Contest ARC 151 A B C D E 题解

    点我看题 昨天刚打的ARC,题目质量还是不错的. A - Equal Hamming Distances 对于一个位置i,如果\(S_i=T_i\),那么不管\(U\)的这个位置填什么,对到\(S\) ...

随机推荐

  1. CF 1042 E. Vasya and Magic Matrix

    E. Vasya and Magic Matrix http://codeforces.com/contest/1042/problem/E 题意: 一个n*m的矩阵,每个位置有一个元素,给定一个起点 ...

  2. iOS 中的正则表达式符号

    最近重新看了一遍 iOS 的正则文档,简单翻译下文档中涉及到的符号 1.正则表达式元字符 符号 说明 \a 响铃, \u0007 \A 匹配输入的开始,只匹配第一行,也就是忽略多行选项 \b 不在[] ...

  3. H5-基础-day01

    类选择器和ID选择器   相同点:可以应用于任何元素不同点: 1.ID选择器只能在文档中使用一次.与类选择器不同,在一个HTML文档中,ID选择器只能使用一次,而且仅一次.而类选择器可以使用多次. 2 ...

  4. Python对象引用问题总结

    对于对象引用问题,一直是一知半解的状态,现整理以备使用. 操作不可变对象进行加减运算时,会在内存中创建新的不可变实例,不会影响原来的引用>>> c=12>>> d= ...

  5. 「专题训练」Boredom(CodeForces Round #260 Div.1 A)

    题意(Codeforces-455A) 给你\(n\)个数,你每次可以选择删除去一个数\(x\)获得\(x\)分,但是所有为\(x+1\)和\(x-1\)的数都得删去.问最大获得分数. 分析 这是一条 ...

  6. 「日常训练」Caterpillar(POJ-3310)

    题意与分析 一条很有趣的题目.给一个无向图,问它是否无环,且可以在上面找到一条线,使所有的顶点要么在线上要么不在线上但在与线相连的边上. 那么首先要确定所有点联系在一起.这个可以同判环一起处理:如果建 ...

  7. 谁说接口不能有代码?—— Kotlin接口简介(KAD 26)

    作者:Antonio Leiva 时间:Jun 6, 2017 原文链接:https://antonioleiva.com/interfaces-kotlin/ 与Java相比,Kotlin接口允许你 ...

  8. 在deepin系统中制作桌面快捷方式

    在使用deepin-wine 安装一些软件的时候,每次启动都需要到.deepinwine目录下运行deepin-wine xx.exe.笔者在安装过HeidiSql之后,一直苦于这种情况.比较好的解决 ...

  9. 腾讯云ubuntu安装使用MySQL

    安装步骤 ubuntu@VM---ubuntu:~$ sudo apt-get install mysql-server (密码: root/root) ubuntu@VM---ubuntu:~$ s ...

  10. CSS动画@-webkit-keyframes

    @-webkit-keyframes:以百分比来规定改变发生的时间,或者通过关键词 "from" 和 "to",等价于 0% 和 100%.0% 是动画的开始时 ...