The Problem to Slow Down You

Time Limit: 1 Sec

Memory Limit: 256 MB

题目连接

http://acm.hust.edu.cn/vjudge/contest/view.action?cid=93645#problem/G

Description

http://7xjob4.com1.z0.glb.clouddn.com/76e435d3c21fa3cbeef1e76780086dc4

Input

 

Output

Sample Input

Sample Output

HINT

题意

给你两个字符串,然后问你这两字符串中 有多少对本质不同的字符串子序列

题解:

回文树,参考 http://blog.csdn.net/u013368721/article/details/42100363

建完树之后,DFS一波就行,模板题

代码:

#include<iostream>
#include<stdio.h>
#include<queue>
#include<map>
#include<string.h>
#include<algorithm>
using namespace std;#define maxn 200005const int MAXN = 200005 ;
const int N = 36 ;
/*
1.求串S前缀0~i内本质不同回文串的个数(两个串长度不同或者长度相同且至少有一个字符不同便是本质不同)
2.求串S内每一个本质不同回文串出现的次数
3.求串S内回文串的个数(其实就是1和2结合起来)
4.求以下标i结尾的回文串的个数
那么我们该如何构造回文树?
首先我们定义一些变量。
1.len[i]表示编号为i的节点表示的回文串的长度(一个节点表示一个回文串)
2.next[i][c]表示编号为i的节点表示的回文串在两边添加字符c以后变成的回文串的编号(和字典树类似)。
3.fail[i]表示节点i失配以后跳转不等于自身的节点i表示的回文串的最长后缀回文串(和AC自动机类似)。
4.cnt[i]表示节点i表示的本质不同的串的个数(建树时求出的不是完全的,最后count()函数跑一遍以后才是正确的)
5.num[i]表示以节点i表示的最长回文串的最右端点为回文串结尾的回文串个数。
6.last指向新添加一个字母后所形成的最长回文串表示的节点。
7.S[i]表示第i次添加的字符(一开始设S[0] = -1(可以是任意一个在串S中不会出现的字符))。
8.p表示添加的节点个数。
9.n表示添加的字符个数。
*/
struct Palindromic_Tree
{int next[MAXN][N] ;//next指针,next指针和字典树类似,指向的串为当前串两端加上同一个字符构成int fail[MAXN] ;//fail指针,失配后跳转到fail指针指向的节点int cnt[MAXN] ;int num[MAXN] ;int len[MAXN] ;//len[i]表示节点i表示的回文串的长度int S[MAXN] ;//存放添加的字符int last ;//指向上一个字符所在的节点,方便下一次addint n ;//字符数组指针int p ;//节点指针int val[MAXN] ;int newnode ( int l ) {//新建节点for ( int i = 0 ; i < N ; ++ i ) next[p][i] = 0 ;cnt[p] = 0 ;num[p] = 0 ;len[p] = l ;return p ++ ;}void init () {//初始化p = 0 ;newnode (  0 ) ;newnode ( -1 ) ;last = 0 ;n = 0 ;S[n] = -1 ;//开头放一个字符集中没有的字符,减少特判fail[0] = 1 ;}int get_fail ( int x ) {//和KMP一样,失配后找一个尽量最长的while ( S[n - len[x] - 1] != S[n] ) x = fail[x] ;return x ;}void add ( int c ) {c+=1;c -= 'a' ;S[++ n] = c ;int cur = get_fail ( last ) ;//通过上一个回文串找这个回文串的匹配位置if ( !next[cur][c] ) {//如果这个回文串没有出现过,说明出现了一个新的本质不同的回文串int now = newnode ( len[cur] + 2 ) ;//新建节点fail[now] = next[get_fail ( fail[cur] )][c] ;//和AC自动机一样建立fail指针,以便失配后跳转next[cur][c] = now ;num[now] = num[fail[now]] + 1 ;}last = next[cur][c] ;cnt[last] ++ ;}int query( int c ){c+=1;c-='a';int cur = get_fail(last);if(!next[cur][c])return 0;last = next[cur][c];return cnt[last];}void count () {for ( int i = p - 1 ; i >= 0 ; -- i ) cnt[fail[i]] += cnt[i] ;//父亲累加儿子的cnt,因为如果fail[v]=u,则u一定是v的子回文串!
    }
} L,R;char s1[maxn];
char s2[maxn];
long long ans=0;
void dfs(int x,int y)
{for(int j=0;j<35;j++){int xx = L.next[x][j];int yy = R.next[y][j];if(xx&&yy){ans += (long long) ( L.cnt[xx] * 1LL * R.cnt[yy] * 1LL ) ;dfs(xx,yy);}}
}
int main()
{int t;scanf("%d",&t);for(int cas=1;cas<=t;cas++){L.init();R.init();scanf("%s",s1);int len = strlen(s1);for(int i=0;i<len;i++)L.add(s1[i]);L.count();scanf("%s",s2);len = strlen(s2);ans = 0;for(int i=0;i<len;i++)R.add(s2[i]);R.count();dfs(0,0);dfs(1,1);printf("Case #%d: %lld\n",cas,ans);}
}

转载于:https://www.cnblogs.com/qscqesze/p/4854662.html

2014-2015 ACM-ICPC, Asia Xian Regional Contest G The Problem to Slow Down You 回文树相关推荐

  1. 2016 ACM / ICPC Asia dalian Regional Contest 题解(11 / 11)【每日亿题2021 / 2 / 17】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 目录 A .(2017 ACM ICPC dalian H)To begin or not to be ...

  2. 2017 ACM ICPC Asia Shenyang Regional Contest 题解(10 / 13)【每日亿题2 / 16】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 目录 A.(2017 ICPC shenyang I)Little Boxes B.(2017 ICP ...

  3. The 2022 ICPC Asia Xian Regional Contest

    题目顺序大致按照难度排序. F. Hotel 现在酒店中有单人间和双人间,价格分别是c1,c2,现在有n个队,每队三个人,性别分别用字母表示,当两个人性别相同且在同一个队时,他们可以住在双人间中.求最 ...

  4. 最大流 ---- 最大密度子图 ----- 2014-2015 ACM-ICPC, Asia Xian Regional Contest C The Problem Needs 3D Arrays

    题目链接 题目大意: 就是给你一个全排列,现在叫你选出一个子序列sss,使得r(s)l(s)\frac{r(s)}{l(s)}l(s)r(s)​最大? r(s)r(s)r(s)是这个子序列的逆序对数 ...

  5. Gym - 101981G The 2018 ICPC Asia Nanjing Regional Contest G.Pyramid 找规律

    数一个n阶三角形中,有多少个全等三角形,n<=1e9 拿到题想找规律,手画开始一直数漏....,最后还是打了个表 (打表就是随便定个点为(0,0),然后(2,0),(4,0),(6,0),(1, ...

  6. 2015 ACM/ICPC Asia Regional Shenyang Online题解

    以下所有AC题解程序来自"仙客传奇"团队. AC题数:7/13 ABCFGJL A. Traversal AC的C++语言程序: #include <bits/stdc++. ...

  7. The 2019 ICPC Asia Shanghai Regional Contest

    The 2019 ICPC Asia Shanghai Regional Contest 题号 题目 知识点 A Mr. Panda and Dominoes B Prefix Code C Maze ...

  8. 2018 ICPC Asia Jakarta Regional Contest

    2018 ICPC Asia Jakarta Regional Contest 题号 题目 知识点 难度 A Edit Distance B Rotating Gear C Smart Thief D ...

  9. 【题目记录】——The 2021 ICPC Asia Jinan Regional Contest

    文章目录 C Optimal Strategy 组合数 H Game Coin K Search For Mafuyu 欧拉序列 题目集地址 The 2021 ICPC Asia Jinan Regi ...

最新文章

  1. (转载)虚幻引擎3--9掌握虚幻技术UnrealScript 预处理器
  2. 第四章函数作业题,函数模板
  3. 初学python,分享一个简单的Excel文档合并工具
  4. opencv双目测距资料整理
  5. 网站降权可从两方面着手分析
  6. 《九章算术》中更相减损术----求最大公约数
  7. 【转】浅析Java中的final关键字
  8. 孤荷凌寒自学python第六十三天学习mongoDB的基本操作并进行简单封装2
  9. chstr php,PHPWind与Discuz截取字符函数substrs与cutstr性能比较
  10. Android开发:Handler Runnable和Thread之间的区别和联系 应用--------------------看完本篇,从此一览无余!...
  11. [渝粤教育] 西南科技大学 数据库应用 在线考试复习资料(5)
  12. 微软ODBC服务器驱动,Microsoft SQL Server ODBC 驱动程序修复
  13. PC串行接口串口定义
  14. 论文中 一级标题、二级标题等 对应格式的统一修改
  15. Codeforces 633C Spy Syndrome 2(Trie+暴力)
  16. linux百度资源网盘,百度网盘 linux版
  17. 深入理解JVM的内存结构及GC机制
  18. 多种模块拔号上网驱动开发调试
  19. 超声波传感器(CH101ch201) - Ⅱ
  20. 从国外官网github下载各种软件安装包项目太慢怎么办

热门文章

  1. s7-200与计算机modbus通讯案例,西门子200MODBUS通讯案例.doc
  2. android添加imageview,android – 以编程方式将ImageView添加到Layout
  3. 奶粉中含PHP作用,奶粉中的益生菌有什么作用
  4. 2016设置方框的尺寸_四种模板脚手架分类、优缺点及参数设置对比
  5. 三线压力传感器原理_弹性式压力表、弹簧管压力表、压阻式压力传感器的原理、选型、安装...
  6. VMware和Linux版本搭配问题
  7. python whl大全
  8. 解放程序员双手之Supervisor
  9. 【思维导图-索引篇】搞定数据库索引就是这么简单
  10. 深入浅出Websocket(二)分布式Websocket集群