CSPS模拟 87
考场上思考量不可减少
否则分数秒变弟弟,考后秒变弱智
T1
二分答案。打的稍恶心
T2
线段树维护“如果我在这个点开枪,前方点的贡献有多大”
想明白了就很好理解了
另外已经飞过去八千里的鸟还输入进来干吗?
T3
暴搜:在有意义的范围内,已知(i,j)可行
若a[i+1]==b[j+1],则(i+1,j+1)可行
若a[i+1]!=b[j+1],则(i+1,j)(i,j+1)可行
在暴搜的基础上打表考虑
还考虑个毛线啊然后两位AK王就打了个表猜了个规律就AC了这道题啊
以A串上的点为基准考虑
如果操作序列和A串完全匹配,那么将取到A串上位置在B串能取到的最左位置
如果和B完全匹配,则取到最右位置
那么把左右端点之间的长度的$\sum$就是答案了,秒过样例,AC!
然后完全过不去对拍
仔细观察(打表)发现,可行区间中间有零星的不可行位置
再观察,发现这些位置两侧的字母在A,B两串中恰好逆序(考场上没打表没能说服自己,学习skyh大神做法)
不可行==逆序?
充分性:假设两个字母逆序(AB BA)而且存在使两个指针分别指向这两个位置的方案
考虑最后一次操作,是A呢?还是B呢?
是A,那BA的指针就向后移动了,是B,AB的指针就跑了
所以字母逆序充分不可行。
必要性:从暴力的过程考虑。把(i,j)看成一个01矩阵,0表示不可行,1表示可行
(i,j)不可行,也即从未有(i-1,j)(i,j-1)(i-1,j-1)向它转移过来。
那么两种情况,要么(i-1,j)(i,j-1)(i-1,j-1)本来就不可行,
要么转移条件不符合,a[i-1]!=b[j-1]&&a[i]==b[j-1]&&a[i-1]==b[j]
考虑到“字母逆序”可表示为:a[i-1]!=b[j-1]&&a[i]==b[j-1]&&a[i-1]==b[j]
形式相同,那么只需充分说明转移条件不符合就可以了
尝试证明状态原本一定全部可行,即可证明转移条件不符合。
由于a[i-1]!=b[j-1],则(i-1,j-1)可以转移到(i,j-1)(i-1,j)
只要(i-1,j-1)可行即可,不可行怎么办,反正一定存在k使(i-k,j-k)可行
这是由于不可行状态是位于可行状态之间(因为讨论的是可行状态间零星的不可行状态)
(可以理解成那个01矩阵中,一条长长的0把左下角和源点(0,0)或(1,1)阻隔开,左下的状态全都无法被转移到,全是0,不在讨论范围内)
所以考虑从左上到右下这串0的 左上角的0,显然满足a[i-1]!=b[j-1]&&a[i]==b[j-1]&&a[i-1]==b[j]
从而a[i]!=b[j]
从而满足a[i]!=b[j]&&a[i+1]==b[j]&&a[i]==b[j+1]
从而a[i+1]!=b[j+1]
从而链式递推下去,所有0全部满足a[i-1]!=b[j-1]&&a[i]==b[j-1]&&a[i-1]==b[j]
所以0的产生原因都是因为转移条件不符合,也即必须满足字母逆序的要求。
所以直接处理6种字母逆序的数量就行了
为什么不是9种
因为在可到达的范围内有相同的字母相邻的话,你可以在A串上还未进入此串相同字符前不断操作此字符,让B指针跳到期望位置的前一个,此时再让A指针移动即可达到目的。
感谢skyh教我做人。
CSPS模拟 87的更多相关文章
- csp-s模拟测试87
csp-s模拟测试87 考场状态还可以$T1$我当时以为我秒切,$T2$确认自己思路不对后毅然决然码上,$T3$暴力挂了太可惜了. 03:01:28 03:16:07 03:11:38 140 03: ...
- CSPS模拟86-87
模拟86 T1,烧水,按位统计贡献,利用某种sao操作避免数位dp #include<iostream> #include<cstdio> #include<cstrin ...
- 反省——关于csp-s模拟50
本人于搜索csp-s模拟49题解时,有意识地点开了一篇关于csp-s模拟50T2的题解,并知道了题解是二维前缀和以及四维偏序. 更重要的是,那篇博客说有解法二,叫二维莫队. 于是我上网搜索二维莫队,结 ...
- csp-s模拟测试99
csp-s模拟测试99 九九归一直接爆炸. $T1$一眼板子. $T2$一眼语文题(语文的唯一一次$120+$是给模拟出来的可知我的语文能力). $T3$一眼普及题. ?? Hours Later 板 ...
- csp-s模拟测试98
csp-s模拟测试98 $T1$??不是我吹我轻松手玩20*20.$T2$装鸭好像挺可做?$T3$性质数据挺多提示很明显? $One$ $Hour$ $Later$ 这$T1$什么傻逼题真$jb$难调 ...
- csp-s模拟测试97
csp-s模拟测试97 猿型毕露.水题一眼秒,火题切不动,还是太菜了. $T1$看了一会儿感觉$woc$期望题$T1??$假的吧??. $T2$秒. $T3$什么玩意儿. 40 01:24:46 00 ...
- csp-s模拟测试96
csp-s模拟测试96 $T1$一眼慢速乘,$T2$稍证一手最优性尝试用神奇数据结构优化,无果,弃.$T3$暴力+信仰. 100 03:16:38 95 03:16:56 35 03:17:10 23 ...
- csp-s模拟测试95
csp-s模拟测试95 去世场祭. $T1$:这不裸的除法分块吗. $T2$:这不裸的数据结构优化$Dp$吗. $T3$:这不裸的我什么都不会搜索骗$30$分吗. 几分钟后. 这除法分块太劲了..(你 ...
- csp-s模拟测试94
csp-s模拟测试94 一场简单题,打爆了.$T1$脑抽分解质因数准备分子分母消,想了半天发现$jb$互质直接上天,果断码了高精滚蛋.$T2$无脑手玩大样例,突然灵光一闪想到映射到前$K$大小的区间, ...
随机推荐
- ef core实现无感知软删除
很多web程序一般的偶不会设计真的物理删除了. 基本上都是在在数据库加一个标记,就得当作已经删除了.同时在查询的时候,过滤已经标记删除的数据 ef core实现软删除是非常简单的,直接在OnModel ...
- python编程基础之五
转义字符:就是不方便从键盘之间输出,或者是原字符有特殊含义的一些字符, 下面列举几个常用的转义字符 \',\",\''',\""",\\,都是表示原字符的意思, ...
- cocos2d-x 系统学习cocos(1)
简析HelloWorld场景 以前使用cocos2d-x 3.14的时候,HelloWorld并不是一个场景类,而是一个图层类,当时的HelloWorld::createScene()是长这样的 Sc ...
- 并发新构件之CyclicBarrier
CyclicBarrier:叫做循环栅栏,名字挺好听的.JDK描述:允许一组线程全部等待彼此达到共同屏障点的同步辅助. 循环阻塞在涉及固定大小的线程方的程序中很有用,这些线程必须偶尔等待彼此. 屏障被 ...
- python 安装pyqt
---恢复内容开始--- 一.安装 1.官网:www.riverbankcomputing.com 2.使用命令安装,可以自动去官网查找与Python版本号相同的程序进行下载,比较方便,如果不是这样也 ...
- Cocos Creator 中 _worldMatrix 到底是什么(中)
Cocos Creator 中 _worldMatrix 到底是什么(中) 1. 中篇摘要 在上篇中主要做了三件事 简单表述了矩阵的基本知识,以及需要涉及到的三角函数知识 推导了图形变换中 位移 .旋 ...
- sql注入100种姿势过waf(二):过安全狗
仅供学习交流如果你有更好的思路可以一起分享,想一起学习的进我主页 先去安全狗网站下载最新的安全狗版本 从官网下载 windwos apache版 v4.0.2395 最新版 数据库是mysql ...
- 05jmeter-responses中有多组json数据,提取同一条json数据的两个字段
某接口返回结果如上图,取id和groupNo 1.读取确定的某条json数据:如取第一条,一个JSON Extractor即可实现 2.随机读取某条json数据: 需要两个JSON Extractor ...
- linux文档、目录相关
linux中常用文档的目录规则: /var 存放经常变化的文件 /home 普通用户家目录 /home/xiaoliu 小刘同学的用户家目录 /etc 存放配置文件的目录 /etc/my.cnf my ...
- 基于mysql-8.0.16-winx64的主从搭建
1.主服务器的my.ini文件内容:[mysqld]# 主库和从库需要不一致server-id=1log-bin=mysql-bin# 同步的数据库binlog-do-db=master-slave# ...