http://www.spoj.com/problems/STC02/en/

题意:给出一个长度为n的字符串,问其中有多少个子串s可以使得s = s按位取反+翻转。

例如样例:11001011.

10可以,因为取反 = 01,翻转 = 10. 所以算一个。

思路:可以看成是回文串,使用Manacher算法求解。

当向两边扩张的时候,判定条件修改成左边是1或者0,右边就是0或者1,或者都是#。

因为那个子串一定是偶数长度,刚好就是s[i] = '#'的时候就更新答案,该位置的回文串对答案的贡献就是本身不包含'#’的长度,因此是p[i] / 2.

有一个点WA了很久。就是只有s[i] = '#'的时候才可以更新mx。为什么要这样呢?

看这个样例就明白了:011

变成:$#0#1#1#

如果不加判定条件的话,扫到第一个1的时候,p[4] = 4,这个时候mx会更新到右端点。

那么等到p[5]的时候,就会变成p[5] = 3,因为执行了 if(mx > i) p[i] = min(p[id*2-i], mx - i); 这个语句。

但是事实上p[5]是不能向外扩张的,p[5] = 1。

还是需要多考虑细节上的问题啊。

 #include <bits/stdc++.h>
using namespace std;
#define N 500010
int p[N*];
char str[N], s[N*]; bool check(char c1, char c2) {
if(c1 == '' && c2 == '' || c1 == '' && c2 == '' || c1 == '#' && c2 == '#') return true;
return false;
} int main() {
int n;
scanf("%d", &n);
scanf("%s", str);
int len = ;
s[len] = '$'; s[++len] = '#';
for(int i = ; i < n; i++) { s[++len] = str[i]; s[++len] = '#'; }
int mx = , id = ;
long long ans = ;
for(int i = ; i <= len; i++) {
if(mx > i) p[i] = min(p[id*-i], mx - i);
else p[i] = ;
while( <= i - p[i] && i + p[i] <= len && check(s[i-p[i]], s[i+p[i]])) p[i]++;
if(s[i] == '#') {
ans += p[i] / ;
if(mx < p[i] + i) { mx = p[i] + i; id = i; } // 只有s[i]为'#'才可以更新mx
}
}
for(int i = ; i <= len; i++) printf("%d: %c %d\n", i, s[i], p[i]);
printf("%lld\n", ans);
return ;
}

SPOJ STC02 - Antisymmetry(Manacher算法求回文串数)的更多相关文章

  1. LOJ 2452 对称 Antisymmetry——用hash求回文串数

    概念 用hash求最长回文串/回文串数 首先,易知,回文串具有单调性. 如果字符串 $s[l...r]$ 为回文串串,那么 $s[x...y]$($l < x, y < r$ 且 $|l- ...

  2. HDU 5371(2015多校7)-Hotaru&#39;s problem(Manacher算法求回文串)

    题目地址:HDU 5371 题意:给你一个具有n个元素的整数序列,问你是否存在这样一个子序列.该子序列分为三部分,第一部分与第三部分同样,第一部分与第二部分对称.假设存在求最长的符合这样的条件的序列. ...

  3. Manacher算法求回文半径

    http://wenku.baidu.com/link?url=WFI8QEEfzxng9jGCmWHoKn0JBuHNfhZ-tKTDMux34CeY8UNUwLVPeY5HA3TyoKU2XegX ...

  4. 马拉车算法——求回文串起点hdu3294

    #include<bits/stdc++.h> using namespace std; #define maxn 500005 int p[maxn]; ]; int start; in ...

  5. Codeforces Global Round 7 D2. Prefix-Suffix Palindrome (Hard version)(Manacher算法+输出回文字符串)

    This is the hard version of the problem. The difference is the constraint on the sum of lengths of s ...

  6. 马拉车,O(n)求回文串

    马拉车,O(n)求回文串 对整个马拉车算法步骤做个总结: 第一步:将每个原字母用两个特殊字符包围如: aaa --> #a#a#a# abab -->#a#b#a#b 同时可以由这个翻倍的 ...

  7. Palindrome - URAL - 1297(求回文串)

    题目大意:RT   分析:后缀数组求回文串,不得不说确实比较麻烦,尤其是再用线段数进行查询,需要注意的细节地方比较多,比赛实用性不高......不过练练手还是可以的.   线段数+后缀数组代码如下: ...

  8. 2021.12.10 P5041 [HAOI2009]求回文串(树状数组求逆序对)

    2021.12.10 P5041 [HAOI2009]求回文串(树状数组求逆序对) https://www.luogu.com.cn/problem/P5041 题意: 给一个字符串 \(S\) ,每 ...

  9. manacher算法,求回文串

    用来求字符串最长回文串或者回文串的总数量 #include<map> #include<queue> #include<stack> #include<cma ...

随机推荐

  1. 让你的sublime text写C代码 (sublime text 2 配置构建C开发环境)

    原则 1. 首先你要配置能够编译C++/C环境 2. window中配置该执行环境的环境变量,能够全局使用 3. sublime Text创建新的构建机制.并设置用改全局编译环境 具体过程 能够编译C ...

  2. 操作系统hosts文件

    为了便于北京和大连两个更好的测试系统.该公司专门申请一个域名:大连r \\ u0026 D侧只需要部署(我方系统全权负责在大连研发.所以在大连并列比较的部署方面easy--不要忘记,该项目比我们实际做 ...

  3. 获取 UIElement 相对于屏幕原点所占用的矩形区域

    原文:获取 UIElement 相对于屏幕原点所占用的矩形区域 <Grid Background="Transparent"> <StackPanel Margi ...

  4. WPF- 模拟触发Touch Events

    原文:WPF- 模拟触发Touch Events 基于API: [DllImport("User32.dll")] public static extern bool Initia ...

  5. PHP模拟POST提交数据并获得返回值之CURL方法(使用PHP extension,然后使用php_curl.dll,很不错)

    今天公司做个东西,需要条用同事的接口,我的代码和他的代码不在同一个域下,但是都是子域. a.ifensi.com与b.ifensi.com的关系. 我需要传递一个关联数组过去,他那边给我返回一个jso ...

  6. 怎样开始GO编程?

    如果你想开始学习GO语法前,请先背熟下述4点: 1. 环境变量: 使用go env查看环境变量 GOARCH/GOHOSTARCH: 体系架构, amd64或386 GOOS/GOHOSTOS: 操作 ...

  7. WPF编游戏系列 之七 动画效果(2)

    原文:WPF编游戏系列 之七 动画效果(2)        上一篇已经对关闭窗口图标进行了动画效果处理,本篇将对窗口界面的显示和关闭效果进行处理.由于所有的动画效果都是针对窗口界面的Canvas,所以 ...

  8. Debug权限提升

    procedure SetPrivilege; var OldTokenPrivileges, TokenPrivileges: TTokenPrivileges; ReturnLength: dwo ...

  9. Cordova 教程地址

    原文:Cordova 教程地址 1.Cordova 官网 http://cordova.apache.org/ 2.Cordova插件库 for android http://cordova.apac ...

  10. WPF——TargetNullValue(如何在绑定空值显示默认字符)

    原文:WPF--TargetNullValue(如何在绑定空值显示默认字符) 说明:在数据绑定时,如果有些字段为空值,那么在数据绑定时可以用默认值来显示为空的字段. </Grid> { L ...