题面

官方题解

模拟赛题解

题解概述:





定义符号AB表示序列A是序列B的子序列,A!B反之。

设操作序列为I,则有AI,B!I,CI,D!I。

可得出条件①B!C且D!A,所以我们只要讨论满足这个条件的情况。

分情况讨论:

  1. c1=c2,则可以进行操作c1,得到的状态仍满足条件①;
  2. c1!=c2,且B'!~C,此时可以进行操作c1;
  3. c1!=c2,且D'!~A,此时可以进行操作c2;
  4. c1!=c2,且D'A,B'C,此时无法进行操作,此情况无解;

    我们还发现第4种情况下,B=...xyxy,D=...yxyx,且B,D长度相等。

    另外,当B以xy结尾,D以yx结尾时,此情况一定无解。

这就证明了当满足条件①时,无解当且仅当B以xy结尾,D以yx结尾。

这样就可以对于数对(x,y)的每一个x,求出对应y的范围(一段区间),然后把其中以yx结尾的y减去(用前缀和实现),就可以得到每一个x的答案了。

总复杂度O(n)。

代码:

#include<bits/stdc++.h>
using namespace std;
#define N 2000007
#define ll long long
int a[N],b[N],s[3][3][N];
char ch[N];
int tar(char c)
{
if(c=='R')return 0;
if(c=='B')return 1;
return 2;
}
int main()
{
//freopen("stone.in","r",stdin);
//freopen("stone.out","w",stdout);
int n,m,i,j,l,r;
ll ans=0;
scanf("%s",ch+1);
n=strlen(ch+1);
for(i=1;i<=n;i++)
a[i]=tar(ch[i]);
scanf("%s",ch+1);
m=strlen(ch+1);
for(i=1;i<=m;i++)
b[i]=tar(ch[i]);
for(int x=0;x<=2;x++)
for(int y=0;y<=2;y++)
{
for(i=2;i<=m;i++)
if(b[i-1]==x&&b[i]==y)
s[x][y][i]=1;
for(i=1;i<=m;i++)
s[x][y][i]+=s[x][y][i-1];
}
l=1,r=1;
while(r<m&&b[r]!=a[1])r++;
ans=r-l+1;
for(i=2;i<=n;i++)
{
if(l<=m&&a[i-1]==b[l])l++;
if(l>m)break;
if(r<m)
{
r++;
while(r<m&&b[r]!=a[i])r++;
}
if(l>r)continue;
int x=a[i-1],y=a[i];
ans+=r-l+1;
if(x!=y)ans-=s[y][x][r]-s[y][x][l-1];
}
printf("%lld\n",ans);
return 0;
}

总结:这个问题通过设出操作序列I,通过子序列的模型来描述题目条件,然后排除一些显然不合法的情况,确立一个有解的基本条件,再在这个条件下递归地讨论一种情况合不合法,最终发现无解的情况比较特殊,于是得到了一个易于判断的无解的充要条件,问题解决。

CF264D - Colorful Stones 题解的更多相关文章

  1. 洛谷CF264D Colorful Stones(子序列匹配,思维)

    洛谷题目传送门 神仙思维题. 对于两个字符串的匹配问题,似乎之前蒟蒻写的HAOI2010最长公共子序列题解中提到的建网格图模型是一种套路? 给一个稍微强一点的样例(把字母换成了ABC) AABCB B ...

  2. codechef Jewels and Stones 题解

    Soma is a fashionable girl. She absolutely loves shiny stones that she can put on as jewellery acces ...

  3. codeforces 264D Colorful Stones

    题目 题目来自于rng_58Orz. 算法 讨论某个状态\((x,y)\)是否可达,\(x\)是狐狸到达的石头,\(y\)是猫的. 题解说,如果满足以下条件,那么它就是可到达状态: \(t[0..y] ...

  4. 2017 ACM-ICPC亚洲区域赛北京站J题 Pangu and Stones 题解 区间DP

    题目链接:http://www.hihocoder.com/problemset/problem/1636 题目描述 在中国古代神话中,盘古是时间第一个人并且开天辟地,它从混沌中醒来并把混沌分为天地. ...

  5. CF1119A Ilya and a Colorful Walk 题解

    Content 有一个长度为 \(n\) 的数组 \(a_1,a_2,a_3,...,a_n\),试求出两个不相等的数之间的距离的最大值. 数据范围:\(3\leqslant n\leqslant 3 ...

  6. CF433B Kuriyama Mirai's Stones 题解

    Content 有一个长度为 \(n\) 的数组 \(a_1,a_2,a_3,...,a_n\).有 \(m\) 次询问,询问有以下两种: \(1~l~r\),求 \(\sum\limits_{i=l ...

  7. Codeforces Round #162 (Div. 2) A~D 题解

    A. Colorful Stones (Simplified Edition) time limit per test 2 seconds memory limit per test 256 mega ...

  8. HDU 全国多校第四场 题解

    题解 A AND Minimum Spanning Tree 参考代码: #include<bits/stdc++.h> #define maxl 200010 using namespa ...

  9. [SinGuLaRiTy] 组合数学题目复习

    [SinGuLaRiTy] Copyright (c) SinGuLaRiTy 2017.  All Rights Reserved. [CQBZOJ 2011] 计算系数 题目描述 给定一个多项式( ...

随机推荐

  1. CI/CD之Gitlab集成Jenkins多分支pipeline实现质量检测和自动发布

    本次实施主要实现: 代码提交gitlab,自动触发Jenkins构建 gitlab发起Merge Request, 需要Jenkins检查通过才可以merge,实现代码review和质量管控 gitl ...

  2. [原创]Spring-Security-Oauth2.0浏览器端的登录项目分享

    1.简介 ​ CitySecurity项目为正式上线项目做得一个Demo,这里主要介绍浏览器端的登录.本项目使用了SpringSecurity实现表单安全登录.图形验证的校验.记住我时长控制机制.第三 ...

  3. HTML+CSS学习笔记整理

    一.标签语义化(重点): 1.可以方便代码的阅读和维护 2.同时让网络爬虫更好的解析从而更好的分析其内容 3.更好的优化引擎 如何做到标签语义化:个人理解是,首先,网页的HTML主要作用在网页的结构上 ...

  4. DataGridView 行数据验证:当输入数据无效时不出现红色感叹号的Bug

    private void dgvView_CellValidating(object sender, DataGridViewCellValidatingEventArgs e){       if ...

  5. VB.net 通过句柄操作其他窗口

    Imports System.TextImports System.Runtime.InteropServices Public Class Form1    ' 相关API函数声明,注释掉的这里没用 ...

  6. APS.NET MVC + EF (11)---过滤器

    过滤器本质就是对动作方法的执行过程进行干预,这种干预可以影响动作方法执行的各个过程.ASP.NET MVC 提供了4种类型的接口,并在接口中定义了各种成员,代表代码执行的各个阶段,这些接口和成员如表1 ...

  7. tkinter事件键盘绑定

    tkinter事件键盘绑定 from tkinter import * root=Tk() #创建一个框架,在这个框架中响应事件 frame=Frame(root, width=200,height= ...

  8. python类的实例化

    class Person(object): # 创建类 def __init__(self, name): # 构造函数 self.name = name def getName(self): # 类 ...

  9. tkinter的trace()变动追踪

    tkinter的trace() 的参数w是写入追踪 from tkinter import * def callback(*args): xl.set(xE.get()) print("改变 ...

  10. delphi 接口

    第四章          接口 前不久,有位搞软件的朋友给我出了个谜语.谜面是“相亲”,让我猜一软件术语.我大约想了一分钟,猜 出谜底是“面向对象”.我觉得挺有趣,灵机一动想了一个谜语回敬他.谜面是“ ...