2021HDU多校第五场1004 Another String-双指针

https://acm.hdu.edu.cn/showproblem.php?pid=7015

 题意:对于每次以i来分割字符串,计算两个分割串的子串的k-匹配的数量。

思路:当我们计算到ans[i]是,我们可以当成从ans[i-1]加上【1-i】字符串和【i+1,n】的k-匹配数量再减去【1-(i-1)】和【i-n】的k-匹配的数量。

sum1[i]:【1-(i-1)】和【i-n】的k-匹配的数量

sum2[i]:【1-i】和【i+1,n】的k-匹配数量

那我们怎么算这个呢,我们设dp1[i][j]代表从i开始和从j开始k-匹配的数量(方向是从1—>n)

然后sum1[i] 就是dp1[0-(i-1)][i]的和,我们求一下前缀和就好了

计算sum2[i]同理,设dp2[i][j]表示反方向从i开始和和从j开始 k-匹配的数量(反向是从n—>1)

然后sum2[i] 就是dp2[(i+1)-n][i]的和

关键点在于我们如何求出dp1[i][j],dp2[i][j]

我们可以枚举d表示他们的距离,每次求出dp1[i][i+d],和dp2[i][i-d]

然后使用双指针优化,dp1[i][i+d]能匹配到 j,那么dp1[i+1][i+1+d]比然也能匹配到 j,那我们下一个可以直接从开始j往后移。

#include <cstdio>
#include <cstring>
#include <string>
#include <cmath>
#include <iostream>
#include <algorithm>
#include <queue>
#include <cstdlib>
#include <stack>
#include <vector>
#include <set>
#include <map>
#include <bitset>
#include <complex>
#define INF 0x3f3f3f3f3f3f3f3f
#define inf 0x3f3f3f3f
#define FILL(a,b) (memset(a,b,sizeof(a)))
#define lson rt<<1
#define rson rt<<1|1
#define lowbit(a) ((a)&-(a))
#define ios std::ios::sync_with_stdio(false);std::cin.tie(0);std::cout.tie(0);
#define fi first
#define sc second
#define pb push_back
#define all(x) (x).begin(),(x).end()
using namespace std;
typedef long long  ll;
typedef unsigned long long  ull;
typedef pair<int,int> pii;
const ll mod=1e9+7;
const ll N =6e6+10;
const double eps = 1e-6;
const double PI=acos(-1);
ll gcd(ll a,ll b){return !b?a:gcd(b,a%b);}
ll re(){ll x;scanf("%lld",&x);return x;}
int dx[8]= {1,0,-1,0,1,1,-1,-1}, dy[8] = {0,1,0,-1,1,-1,1,-1};
int n,k;
int dp1[3100][3100],dp2[3100][3100];
ll sum1[3100],sum2[3100];
char s[3100];
void solve(){cin>>n>>k;scanf("%s",s+1);for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){dp1[i][j]=dp2[i][j]=0;}sum1[i]=sum2[i]=0;}for(int i=1;i<n;i++){if(s[i]==s[i+1]||k>0) dp1[i][i+1]=1;if(s[i]==s[i+1]||k>0) dp2[i+1][i]=1;}for(int d=2;d<n;d++){int j=-1;int x=0;for(int i=1;i+d<=n;i++){while(x<=k&&i+d+j<=n&&j<d){j++;if(i+d+j>n) break;if(s[i+j]!=s[i+d+j]) x++;}dp1[i][i+d]=j;if(s[i]!=s[i+d]) x--;j--;}}for(int d=2;d<n;d++){int j=-1;int x=0;for(int i=n;i-d>=1;i--){while(x<=k&&i-d-j>=1&&j<d){j++;if(i-d-j<1) break;if(s[i-j]!=s[i-d-j]) x++;}dp2[i][i-d]=j;if(s[i]!=s[i-d]) x--;j--;}}for(int i=1;i<n;i++){for(int j=i+1;j<=n;j++){sum2[i]+=dp2[j][i];}}for(int i=2;i<=n;i++){for(int j=1;j<i;j++){sum1[i]+=dp1[j][i];}}ll ans=0;for(int i=1;i<n;i++){ans+=(sum2[i]-sum1[i]);cout<<ans<<endl;}
}
int main()
{//  ioscin>>t;while(t--) solve();return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315248.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 默认接口方法更新完成,很多细节问题尚待解决

随着对默认接口方法的支持越来越接近完成&#xff0c;一些潜在的问题被提了出来。虽然已经完成了很多工作&#xff0c;但这是一个复杂的特性&#xff0c;许多细节问题还没有解决。但首先&#xff0c;这里有一些已解决的问题。接口允许使用 static 和 const 字段了。除 和! 之外…

【洛谷3768】简单的数学题【莫比乌斯反演】【杜教筛】【小学奥数】

传送门 题意&#xff1a;给定p,Np,Np,N,求 ∑i1N∑j1Nijgcd(i,j)modp\sum_{i1}^{N}\sum_{j1}^{N}ijgcd(i,j)\text{ }mod \text{ }pi1∑N​j1∑N​ijgcd(i,j) mod p ppp为质数&#xff0c;在1e91e91e9左右 N≤1e10N \leq 1e10N≤1e10 神仙题 前置芝士&#xff1a;杜教筛 懒得…

newcode Gene Tree 点分治

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 求一棵树的每对叶子节点之间距离平方的和。 思路&#xff1a; 这个题貌似可以容斥&#xff0c;但是我不会&#xff0c;所以我写了个淀粉质。 要知道&#xff0c;淀粉质的思想就是将子树内部的递归处理&…

2021HDU多校第九场1008HDU7073 Integers Have Friends 2. 随机化

HUD地址&#xff1a;https://acm.hdu.edu.cn/showproblem.php?pid7073 题目大意&#xff1a;选择数组中最多的数&#xff0c;使得他们模m同余&#xff08;m>2&#xff09;。求最大的数量。 思路&#xff1a;然后我们全选奇数或者全选偶数的话&#xff0c;那么我们的答案是…

一个引发程序员们干架的问题

这里是Z哥的个人公众号每周五早8点 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「77」篇原创敬上在一个分布式系统的开发团队中&#xff0c;有一些问题是很容易产生程序员之间矛盾的。其中之一就是「业务归属」&#xff0c;就是当新加/修改一个业务的时候&a…

newcode Islands 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两个圆&#xff0c;上面依次有nnn个点&#xff0c;编号为1−n1-n1−n的排列&#xff0c;给出一种连边方式&#xff0c;使得每个点都被遍历且连线不能相交&#xff0c;没有方式的话输出−1-1−1。 思路&…

微服务探索与实践—服务注册与发现

前言微服务从大规模使用到现在已经有很多年了&#xff0c;从之前的探索到一步步的不断完善与成熟&#xff0c;微服务已经成为众多架构选择中所必须面对的一个选项。服务注册与发现是相辅相成的&#xff0c;所以一般会合起来思索。其依托组件有很多&#xff0c;比如Zookeeper,Co…

快速沃尔什变换:从入门到背板(含推导过程)

前&#xff08;che&#xff09;言&#xff08;dan&#xff09; FWTFWTFWT是个神奇的东西。 然而网上多数讲解多数直接给结论&#xff0c;顶多用归纳法证一证。 所以本文会讲解FWTFWTFWT的推导过程。 虽然也用到了构造&#xff0c;但是好背得多 参考博客&#xff1a;https:/…

微服务探索与实践—总述

背景软件开发是一个不断发展的过程&#xff0c;从当初的面向过程为主到如今的面向对象的开发&#xff0c;软件开发者不断探索与实践更加符合时代发展要求的开发模式与架构思想&#xff0c;而这&#xff0c;也在极大程度上提高了软件开发的效率。微服务是一种架构模式或者说是架…

P4097 [HEOI2013]Segment 李超线段树

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 实现以下两个操作&#xff1a; (1)(1)(1)在平面上加入一条线段。记第iii条被插入的线段的标号为iii (2)(2)(2)给定一个数kkk&#xff0c;询问与直线xkxkxk相交的线段中&#xff0c;交点纵坐标最大的线段的编…

【CF1204D】Kirk and a Binary String【结论题】【LIS】

传送门 题意&#xff1a;给一个01串SSS&#xff0c;求一个等长的01串TTT SSS和TTT所有对应位置的子串最长不下降子序列长度&#xff08;以下简称LIS\text{LIS}LIS&#xff09;相同TTT中0的数量尽量多 ∣S∣≤100000|S| \leq 100000∣S∣≤100000 对于一个01串SSS&#xff0c;…

这周,全球首个IT技术全中文免费学习平台诞生了!太惊艳!

本周三的Developer Wednesday为大家揭秘了Microsoft Learn网站的全新学习模式一时间Microsoft Learn圈粉无数如果你正在为错过直播而暴风哭泣等一等&#xff0c;看这里&#xff01;全程高清回播将为你持续解密这一次你一定不可以再错过了哦&#xff01;什么是Microsoft Learn&…

【CF1182D】Complete Mirror【树的重心】

传送门 题意&#xff1a;给一棵NNN个结点的树&#xff0c;你需要钦定一个根&#xff0c;使得所有深度相同的点的度数相同。 N≤100000N \leq 100000N≤100000 用脑子想一想&#xff0c;就是根节点直接相连的子树都长得一模一样。 如果根节点度数大于1&#xff0c;我们发现它…

P1989 无向图三元环计数 思维 + 建图

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 统计无向图中三元环的个数。 思路&#xff1a; 很明显有一种暴力的方法&#xff0c;就是枚举每条边&#xff0c;让后再跑两个点的所有边&#xff0c;可以卡到复杂度O(m2)O(m^2)O(m2)。 我们可以考虑给点之…

十分钟了解Kubernetes

何为Kubernetes?最简单的一句话来概括Kubernetes。它就是一套成熟的商用服务编排解决方案。Kubernetes定位在Paas层&#xff0c;重点解决了微服务大规模部署时的服务编排问题。Kubernetes组件介绍了解Kubernetes都是从Pod开始的。Pod是Kubernetes最小的调度单元&#xff0c;所…

【CF1020C】Election【贪心】

传送门 题意&#xff1a;NNN个人给MMM个党派投票&#xff0c;开始时每个人选择一个党派投票&#xff08;给定&#xff09;&#xff0c;每个人可以花费一定代价贿赂&#xff08;每个人给定代价&#xff09;&#xff0c;求让1号党派胜出&#xff08;票数严格最大&#xff09;的最…

Codeforces Round #627 (Div. 3) E. Sleeping Schedule dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一天hhh小时&#xff0c;初始时间是000&#xff0c;每天可以使时间aia_iai​或者ai−1a_i-1ai​−1&#xff0c;问最多可以让多少天的时间在[l,r][l,r][l,r]范围内。 思路&#xff1a; 算是个比较简单…

【CF1194E】Count The Rectangles【类扫描线】【单调性】【树状数组】

传送门 题意&#xff1a;给定NNN条与坐标轴平行的线段&#xff0c;保证不垂直的线段没有交点&#xff0c;求一共构成多少个矩形&#xff08;以线段交点为顶点&#xff09;。 1≤N≤50001\leq N\leq50001≤N≤5000 显然是个数据结构乱搞题。 直觉告诉我们先枚举一条线段。 假…

.NET Core 的过去、现在和未来

在最新的微软 Build 大会主题网站上&#xff0c;微软.NET 程序经理 Scott Hunter 发表了一篇文章&#xff0c;指出.NET Core 是.NET 的未来。去年&#xff0c;微软就已经确认 Visual Studio Live 中的.NET 框架将会被.NET Core 取代。将.NET Core 作为开源开发技术栈在 2014 年…

Ozon Tech Challenge 2020 (Div.1 + Div.2) C. Kuroni and Impossible Calcul 抽屉原理

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一个数组ana_nan​&#xff0c;求∏1≤i<j≤n∣aj−ai∣modm\begin{matrix} \prod_{1\le i<j\le n} |a_j-a_i| \end{matrix}\bmod m∏1≤i<j≤n​∣aj​−ai​∣​modm。 n≤2e5,m≤1e3n\le2e5…