【CF598 Div3 F】Equalizing Two Strings
- 一道通篇结论的傻逼题,被 lh 随手秒了
- 别告诉我你不会 Div3 的题,你肯定在 fake
- 没看过题解,以下做法纯属口胡,应该没问题
Description
https://www.luogu.org/problem/CF1256F
Solution
首先,若两个字符串的字符集不相同,答案必定是 no。
由于 \(L\) 随便选取,我们又只需要判断 yes 或 no,不难发现任何 \(L\gt 2\) 的操作都可以拆成若干个 \(L=2\) 的操作。
故当所有操作的 \(L\) 为 \(2\) 时(即每次交换相邻 \(2\) 位),若存在合法方案,则原问题存在合法方案(yes);否则原问题不存在合法方案(no)。
首先,如果两个串中任意一个存在 \(2\) 个相同字符,则答案必定是 yes。因为你可以把这个串的这 \(2\) 个相同字符移到一起,然后在以后的每次操作中,对于这个串交换这两个字符,对于另一个串交换某 \(2\) 个相邻位,把另一个串逐步变成这个串。由于两串字符集相同,另一个串最终一定可以变成这个串。
下面考虑两个串的串内 都不存在相同字符的情况。
可以用类似的做法,一直交换第一个串的前 \(2\) 位,每次交换第二个串的某 \(2\) 个相邻位,把第二个串逐步变成第一个串。
显然最后两个串要么相等,要么前 \(2\) 位相反。前一种情况的答案是 yes,后一种情况的答案是 no。
即我们只需要判断第二个串变成第一个串 用了奇数次还是偶数次操作。
我们发现没法求用了多少次操作,但我们可以给两个串同时加、减若干次操作,使其变得容易计算。
由于两个串的串内 所有字符各不相同,我们可以让它们都变成上升序列,判断两个串各自变成上升序列的操作次数 奇偶性是否相同即可。(显然各自的操作次数是唯一的)
为什么可以等价转化成这样呢?
不难发现,由于两个串字符集相同,且每个串内所有字符各不相同,所以两个串各自把所有字符从小到大排序后 得到的串相同。
把两个串都变成升序后,我们可以对两个串分别后接相同次交换操作,使它们都变成原来的第一个串。
这些后接的交换操作 可能会与之前的某些交换操作相反,比如之前交换了一次第 \(3,4\) 位,现在又交换了一次第 \(3,4\) 位。这两次操作显然可以抵消,因为一个操作序列中,任意两次交换操作 都可以交换(可以自己验证一下),我们可以把这两次操作交换到相邻位置,此时这两个相邻相反操作就显然可以抵消了。
抵消完后,第一个串所有操作都被抵消了(因为你把第一个串变成升序后又变回去了),第二个串剩余的操作就是其原串变成第一个串所需的次数。
后接交换操作 不会影响两个串的操作次数的奇偶关系,最后第一个串的操作次数被抵消成了 \(0\)(偶数),若第二个串的操作次数为奇数,则答案为 no,因为你每次操作要顺带交换第一个串的相邻两位,但第一个串操作奇数次后不可能和原来一样;若第二个串的操作次数为偶数,则答案为 yes。
故,若两个串各自变成上升序列的操作次数 奇偶性相同,答案为 yes;否则答案为 no。
现在问题转化成了求两个串变成上升序列 需要多少次操作。
这又是一个经典的经验考察,结论是逆序对个数。
证明(本来我忘了,我现场花了点时间重新发明的):一个序列不为升序时,必定存在两个相邻的逆序字符,而交换这两位会使逆序对数 \(-1\)(因为只有这两位字符的相对顺序变了,这两位与序列中其它位字符的相对顺序没变)。
于是直接求逆序对个数就行了。实际上此时串长不超过 \(26\),怎么做都可以,多组数据的最坏时间是 \(O(26\sum n)\)……
口胡,所以没代码。
【CF598 Div3 F】Equalizing Two Strings的更多相关文章
- 【图灵杯 F】一道简单的递推题(矩阵快速幂,乘法模板)
Description 存在如下递推式: F(n+1)=A1*F(n)+A2*F(n-1)+-+An*F(1) F(n+2)=A1*F(n+1)+A2*F(n)+-+An*F(2) - 求第K项的值对 ...
- 【CF1256F】Equalizing Two Strings(逆序对)
题意:给定两个长度均为n且由小写字母组成的字符串,可以进行若干次操作,每次从两个串中分别选一个长度相等的子串进行翻转,问是否存在能使两串相等的一系列操作方案 n<=2e5 思路:首先如果每种字母 ...
- 【C++竞赛 F】yyy的三角形
时间限制:2s 内存限制:32MB 问题描述 yyy对三角形非常感兴趣,他有n个木棍,他正在用这些木棍组成三角形.这时xxx拿了两根木棍过来,xxx希望yyy能给他一根木棍,使得xxx可以组成一个三角 ...
- 【Cf #502 F】The Neutral Zone
本题把$log$化简之后求得就是每个质数$f$前的系数,求系数并不难,难点在于求出所有的质数. 由于空间限制相当苛刻,$3e8$的$bitset$的内存超限,我们考虑所有的除了$2$和$3$以外的质数 ...
- 【刷题-LeetCode】205. Isomorphic Strings
Isomorphic Strings Given two strings *s* and *t*, determine if they are isomorphic. Two strings are ...
- 【ATcoder s8pc_3 F】 寿司
http://s8pc-3.contest.atcoder.jp/tasks/s8pc_3_f (题目链接) 题意 有一个长度为$N$的数列$A$,初始为$0$.$Q$次操作,每次两个参数$x,y$. ...
- CF598: div3解题报告
CF598:div3解题报告 A: Payment Without Change 思路: 按题意模拟即可. 代码: #include<bits/stdc++.h> using namesp ...
- 【CF1256】Codeforces Round #598 (Div. 3) 【思维+贪心+DP】
https://codeforces.com/contest/1256 A:Payment Without Change[思维] 题意:给你a个价值n的物品和b个价值1的物品,问是否存在取物方案使得价 ...
- 【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并
[Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只 ...
随机推荐
- How to Create and Use Facebook Messenger Codes (June 2019)
How to Create and Use Facebook Messenger Codes (June 2019) By Gerardo Salandra What is a Messenger ...
- C# 添加日志文件
StreamWriter log_sw; // 新建文件 log_sw = File.AppendText(log_str); // 写入日志文件 log_sw.WriteLine(s + " ...
- Hash冲突的四种解决办法
一.哈希表简介 非哈希表的特点:关键字在表中的位置和它自检不存在一个确定的关系,查找的过程为给定值一次和各个关系自进行比较,查找的效率取决于给定值进行比较的次数. 哈希表的特点:关键字在表中位置和它自 ...
- C语言--单层循环结构
一.PTA实验作业 题目1:最佳情侣身高 1.实验代码 int N, i; float height; char sex; printf("输入用户个数:\n"); scanf(& ...
- JavaWeb开发常用的前端控件
罗列的下述控件大多依赖jquery插件,故可提前导入jquery插件以免出错 Validform 提供对表单的验证.提交等功能,具体可查阅其官方文档>>>Validform 示例如下 ...
- TypeScript 解构
⒈解构数组 最简单的解构莫过于数组的解构赋值了: let input = [1, 2]; let [first, second] = input; console.log(first); // out ...
- python基础(十三)--os和sys模块
os模块 os.getpwd():获取当前工作目录(windows下没有) os.listdir(path):列出目录下的文件 os.remove(path):删出文件 (不能是目录,即文件夹) os ...
- python以不同方式打印输出九九乘法表
参考:http://www.cnblogs.com/suiy-160428/p/5594389.htmlpython输出 9*9 乘法口诀表 矩形输出九九乘法表: for i in range(1,1 ...
- element-ui组件dialog遇到form
Vue.js似乎成了一种潮流. UI框架element-ui也跟着成了一种潮流,不过得承认,至少我个人还是非常认可的,element-ui做的是真不错. 用到element-ui,那么在dialog中 ...
- BMP RGB888转RGB565 +上下翻转+缩放
典型的BMP图像文件由四部分组成: (1) 位图头文件数据结构,它包含BMP图像文件的类型.文件大小和位图起始位置等信息: typedef struct tagBITMAPFILEHEADER { ...