• 一道通篇结论的傻逼题,被 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的更多相关文章

  1. 【图灵杯 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项的值对 ...

  2. 【CF1256F】Equalizing Two Strings(逆序对)

    题意:给定两个长度均为n且由小写字母组成的字符串,可以进行若干次操作,每次从两个串中分别选一个长度相等的子串进行翻转,问是否存在能使两串相等的一系列操作方案 n<=2e5 思路:首先如果每种字母 ...

  3. 【C++竞赛 F】yyy的三角形

    时间限制:2s 内存限制:32MB 问题描述 yyy对三角形非常感兴趣,他有n个木棍,他正在用这些木棍组成三角形.这时xxx拿了两根木棍过来,xxx希望yyy能给他一根木棍,使得xxx可以组成一个三角 ...

  4. 【Cf #502 F】The Neutral Zone

    本题把$log$化简之后求得就是每个质数$f$前的系数,求系数并不难,难点在于求出所有的质数. 由于空间限制相当苛刻,$3e8$的$bitset$的内存超限,我们考虑所有的除了$2$和$3$以外的质数 ...

  5. 【刷题-LeetCode】205. Isomorphic Strings

    Isomorphic Strings Given two strings *s* and *t*, determine if they are isomorphic. Two strings are ...

  6. 【ATcoder s8pc_3 F】 寿司

    http://s8pc-3.contest.atcoder.jp/tasks/s8pc_3_f (题目链接) 题意 有一个长度为$N$的数列$A$,初始为$0$.$Q$次操作,每次两个参数$x,y$. ...

  7. CF598: div3解题报告

    CF598:div3解题报告 A: Payment Without Change 思路: 按题意模拟即可. 代码: #include<bits/stdc++.h> using namesp ...

  8. 【CF1256】Codeforces Round #598 (Div. 3) 【思维+贪心+DP】

    https://codeforces.com/contest/1256 A:Payment Without Change[思维] 题意:给你a个价值n的物品和b个价值1的物品,问是否存在取物方案使得价 ...

  9. 【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

    [Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只 ...

随机推荐

  1. linux ssh利用公钥免密登陆

    1.安装检查ssh 如果没有ssh的话,需要安装 #yum  install -y openssh-server openssh-clients 2.生成秘钥 ssh-keygen -t rsa 执行 ...

  2. GRU网络

    1.GRU(Gated Recurrent Unit) 为了克服RNN无法远距离依赖而提出了LSTM,而GRU是LSTM的一个变体,GRU保持LSTM效果的同时,又使结构变得简单. 2.GRU结构 G ...

  3. Python学习笔记——pickle 模块

    由于从文本文件中读取出来的内容都会变成字符串,且转换成列表.字典等数据类型比较困难,因此采用pickle模块存储它们 import pickle my_list = [123,3.14,'小甲鱼',[ ...

  4. Reactor系列(二)Flux Mono创建

    Flux Mono创建 视频讲解:https://www.bilibili.com/video/av78844777/ FluxMonoTestCase.java package com.exampl ...

  5. Docker pull php:7.1-fpm的php.ini配置修改

    今天,换了 Deepin 操作系统,开发环境是通过 Docker 搭建的,具体结构如下: CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES e ...

  6. PTA(Advanced Level)1050.String Subtraction

    Given two strings S1 and S2, S=S1−S2 is defined to be the remaining string after taking all the char ...

  7. LINUX添加新的用户账号并赋予root权限

    一:添加新的用户账号使用 useradd 命令 语法:     useradd  选项  用户名 示例:      # 添加用户,设定登录目录:useradd -d  /home/admin -m a ...

  8. 【AtCoder】ARC063

    ARC063 C - 一次元リバーシ / 1D Reversi 不同的颜色段数-1 #include <bits/stdc++.h> #define fi first #define se ...

  9. varnish CLI管理

    命令:varnishadm [-t timeout] [-S secret_file] [-T address:port] [-n name] [command [...]] ./varnishadm ...

  10. 怎样理解在函数中声明var x = y = 1后调用函数时, x是局部变量, y是全局变量

    下面这段代码在执行的时候, 打印的结果是1, Error: undefined; function fn() { var x = y = 1; } fn(); console.log(y); // 1 ...