HDU 6068 - Classic Quotation | 2017 Multi-University Training Contest 4
/*
HDU 6068 - Classic Quotation [ KMP,DP ] | 2017 Multi-University Training Contest 4
题意:
给出两个字符串 S[N], T[M], k个询问
每个询问给出 L,R
对所有 1<=i<=L , r<=j<=N ,
S串拿掉[i+1,j-1]的子串后,剩下两个子串拼在一起的子串中 T 串的数目求和
限制 N,k <= 5e4, M <= 100
分析:
pre[i] 代表 前缀i匹配的T的数目
num[i][j] = 1 代表 前缀i,失配位置为 j
将 pre[i], num[i][j] 求前缀和
suf[i][j] 代表 后缀i,从T[j]开始匹配上的T的数目
ans = pre[L] * (n-R+1) + ∑_[1<=i<=m] num[l][i] * suf[R][i]
所以对于每个询问可 O(m) 时间内求出 pre[i], num[i][j] 可 KMP 过程中求出 设 match[j][k] = 1 代表 T 匹配到 j 时,主串字符为 k 时,新增答案
nxt2[j][k] 代表 T 匹配到 j 时,主串字符为 k 时,下一个失配位置
suf[i][j] = match[j][S[i]] + suf[i+1][nxt[j][S[i]]]
所以 suf可以从后往前 DP
而 match[j][k] 和 nxt2[j][k] 可以 O(m*26) 的时间内暴力求
*/
#include <bits/stdc++.h>
using namespace std;
const int N = 50005;
const int M = 105;
char y[N], x[M];
int nxt[N];
void GetNxt(char x[], int m)
{
int i = 0, j = -1;
nxt[0] = -1;
while (i < m)
{
while (j != -1 && x[i] != x[j]) j = nxt[j];
nxt[++i] = ++j;
}
}
int t, n, m, q;
int pre[N];
int num[N][M];
int suf[N][M];
int nxt2[M][256];
bool match[M][256];
void init()
{
memset(pre, 0, sizeof(pre));
memset(num, 0, sizeof(num));
memset(match, 0, sizeof(match));
memset(suf, 0, sizeof(suf));
int j = 0;
for (int i = 0; i < n; i++)
{
while (j != -1 && y[i] != x[j]) j = nxt[j];
j++;
if (j == m) pre[i]++, j = nxt[j];
num[i][j]++;
pre[i] += pre[i-1];
}
for (int i = 1; i < n; i++)
{
pre[i] += pre[i-1];
for (int j = 0; j < m; j++)
num[i][j] += num[i-1][j];
}
for (int i = 0; i < m; i++)
for (int j = 'a'; j <= 'z'; j++)
{
int k = i;
while (k != -1 && x[k] != j) k = nxt[k];
k++;
if (k == m) match[i][j] = 1, k = nxt[k];
nxt2[i][j] = k;
}
for (int i = n-1; i >= 0; i--)
for (int j = 0; j < m; j++)
suf[i][j] = match[j][y[i]] + suf[i+1][nxt2[j][y[i]]];
for (int i = n-1; i >= 0; i--)
for (int j = 0; j < m; j++)
suf[i][j] += suf[i+1][j];
}
int main()
{
scanf("%d", &t);
while (t--)
{
scanf("%d%d%d", &n, &m, &q);
scanf("%s%s", y, x);
GetNxt(x, m);
init();
while (q--)
{
int l, r; scanf("%d%d", &l, &r);
l--, r--;
long long ans = 1LL * (n-r)*pre[l];
for (int i = 0; i < m; i++)
ans += 1LL * num[l][i] * suf[r][i];
printf("%lld\n", ans);
}
}
}
HDU 6068 - Classic Quotation | 2017 Multi-University Training Contest 4的更多相关文章
- hdu 6068 Classic Quotation
题 QAQ http://acm.hdu.edu.cn/showproblem.php?pid=6068 2017 Multi-University Training Contest - Team 4 ...
- HDU 6068 Classic Quotation KMP+DP
Classic Quotation Problem Description When online chatting, we can save what somebody said to form h ...
- HDU 6170 - Two strings | 2017 ZJUT Multi-University Training 9
/* HDU 6170 - Two strings [ DP ] | 2017 ZJUT Multi-University Training 9 题意: 定义*可以匹配任意长度,.可以匹配任意字符,问 ...
- hdu 6301 Distinct Values (2018 Multi-University Training Contest 1 1004)
Distinct Values Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
- hdu 5288 OO’s Sequence(2015 Multi-University Training Contest 1)
OO's Sequence Time Limit: 4000/2000 MS (Jav ...
- hdu 5416 CRB and Tree(2015 Multi-University Training Contest 10)
CRB and Tree Time Limit: 8000/4000 MS (J ...
- HDU 4944 FSF’s game(2014 Multi-University Training Contest 7)
思路: ans[n]= ans[n-1] + { (n,1),(n,2).....(n,n)} 现在任务 是 计算 { (n,1),(n,2).....(n,n)}(k=n的任意因子) 很明显 ...
- HDU 4940 Destroy Transportation system(2014 Multi-University Training Contest 7)
思路:无源汇有上下界可行流判定, 原来每条边转化成 下界为D 上界为 D+B ,判断是否存在可行流即可. 为什么呢? 如果存在可行流 那么说明对于任意的 S 集合流出的肯定等于 流入的, ...
- HDU 4627 The Unsolvable Problem 2013 Multi-University Training Contest 3
给你一个数 n ( 2 <= n <= 109 ),现在需要你找到一对数a, b (a + b = n),并且使得LCM(a, b)尽可能的大,然后输出最大的 LCM(a, b). (为什 ...
随机推荐
- Ckeditor5显示css样式
Ckeditor5在编辑模式是通过js加载样式的,但是在显示时没有提供,官方提供了两种方式来实现. https://ckeditor.com/docs/ckeditor5/latest/builds/ ...
- redis集群(多机)分布
一.实现原理 一致性哈希算法(Consistent Hashing): http://www.zsythink.net/archives/1182 二.配置两个redis服务,端口号要不一致 三.代码 ...
- 12.如何设置ulimit
ulimit -a用来显示当前的各种用户进程限制 修改所有 linux 用户的环境变量文件:vi /etc/profileulimit -u 10000 #用户的最大进程数u ...
- XSS跨站攻击靶场-通关笔记
XSS攻击是Web攻击中最常见的攻击手法之一,XSS中文名跨站脚本攻击,该攻击是指攻击者在网页中嵌入恶意的客户端脚本,通常是使用JS编写的恶意代码,当正常用户访问被嵌入代码的页面时,恶意代码将会在用户 ...
- 使用haystack实现django全文检索搜索引擎功能
前言 django是python语言的一个web框架,功能强大.配合一些插件可为web网站很方便地添加搜索功能. 搜索引擎使用whoosh,是一个纯python实现的全文搜索引擎,小巧简单. 中文搜索 ...
- 数值分析-Legendre正交多项式 实现函数逼近
数值分析-Legendre正交多项式 实现函数逼近 2016年12月18日 21:27:54 冰三点水 阅读数 4057 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请 ...
- shell使用ps -ef|grep xxx时不显示grep xxx进程的方法
在使用ps -ef|grep xxx时会将grep xxx的进程也带出来, 而在脚本中如果想要截取此命令结果的一部分,则grep xxx的进程会显得多余,如下: [root@localhost ~]# ...
- 怎样理解"不推荐不使用var的变量声明方式"这句话
答: 因为不使用var声明的变量不会被预解析, 如下: console.log(a); console.log(b); var a = 1; b = 2;
- spring-boot-plus集成Shiro+JWT权限管理
SpringBoot+Shiro+JWT权限管理 Shiro Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理. 使用Shiro的易于理解的API,您可以 ...
- spring——自动装配
语法:<bean id="..." class="..." autowire="byType"/> autowire属性取值如下 ...