首页 > 其他分享 >Codeforces 1037C Equalize 题解

Codeforces 1037C Equalize 题解

时间:2024-05-17 19:30:12浏览次数:25  
标签:rvert int 题解 Codeforces ++ Equalize neq 代价 define

题目描述

给定两个长度为 $n$ 的 $01$ 序列 $a,b$。

每次可以执行如下操作:

  1. 在 $a$ 中选择一个位置 $p$,将 $a_p$ 变为 $1-a_p$,代价是 $1$。
  2. 在 $a$ 中选择两个位置 $p,q$,将 $a_p$ 和 $a_q$ 互换,代价是 $\lvert q-p \rvert$。

问最少需要多少代价才能将 $a$ 变成 $b$。

题目分析

对于操作二,仅当 $a_q \neq a_p$,$b_q \neq b_p$,并且 $a_q \neq b_q$ 时才能使用,此时代价为 $\lvert q-p \rvert$。同时它也可以等价为操作一,即在 $p$ 和 $q$ 位值各执行一次操作一,这样的代价为 $2$。所以只有 $\lvert q-p \rvert \lt 2$ 时执行操作二是优的,其他情况一律执行操作一。

代码

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define random(a,b) (rand()%(b-a+1)+a)
#define se second
#define fi first
#define pr pair<int,int>
#define pb push_back
#define ph push
#define ft front
#define For(i,a,b) for(int i=a;i<=b;i++)
#define Rep(i,a,b) for(int i=a;i>=b;i--)
#define mem(a,b) memset(a,b,sizeof a)
const int N=1e6+10;
int n,ans;
char a[N],b[N];
int main()
{
	ios::sync_with_stdio(false);
    cin.tie(0);
    cin>>n>>a+1>>b+1;
    For(i,1,n)
	{
		if(a[i]!=b[i]&&a[i+1]!=b[i+1]&&a[i]!=a[i+1])
		{
			i++;
			ans++;
		}
		else if(a[i]!=b[i]) ans++;
	} 
	cout<<ans;
	return 0;
}

标签:rvert,int,题解,Codeforces,++,Equalize,neq,代价,define
From: https://www.cnblogs.com/zhuluoan/p/18198449

相关文章

  • CF1884D Counting Rhyme 题解
    题目链接:CF或者洛谷给个莫反题解,讲讲常规套路题目要求满足没有\(a_k\mida_i与a_k\mida_j\)的\((i,j)\)的对数,显然即不存在\(a_k\mid\gcd(a_i,a_j)\)。稍微拓展下,如果不存在整除多个数,那么显然不整除它们的\(\gcd\)即可,因为它们的公因数即为满足的最大数,如果为......
  • ArchLinux/Manjaro升级到6.9内核后的问题解决
    1.KDEWallet系统配置---个性化---账户详细信息---kde钱包1.需要启用kde钱包子系统,否则无法正常使用记录的账号密码信息2.右下角,调用钱包管理器,修改密码,设置为空密码至此,开机需要输密码连接kdewallet的应用不需要输入即可密码连接2.更新archcn-keyring报GPG错误解决:sudopa......
  • P10466的题解
    (一)出门左转P3369。只需要同时记录原本属于哪一位即可。这里给出Splay做法。(二)AC代码。建议自己打一遍巩固印象。虽然我是直接拉过来的。#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;inlineintread(){intx=0,f=1;charc=getchar();wh......
  • Ollama的常见问题解答(FAQ)
     1如何更新Ollama? 在macOS和Windows上,Ollama会自动检查更新。只需点击任务栏或菜单栏图标,然后选择“重启以更新”来应用新版本。 在Linux上,需要重新运行安装脚本来升级。 2如何查看日志? 查阅特定的故障排查文档来了解如何查看和使用日志。 3我的GPU是否兼容Ollama? ......
  • 题解:CF1954F Unique Strings
    link计数类*3100首次独立过纪念版题解。首先我们考虑一个去重的问题。貌似针对循环同构去重的问题,只能从循环节上入手。那么我们考虑设\(dp(d)\)为最小循环节长度恰好为\(d\)不同方案数个数,则答案为:\[\sum_{d=1}^ndp(d)=\sum_{d|n}\frac{dp(d)}{d}\]这似乎是一条可行......
  • 2024 jscpc B题 Area of the Devil 题解
    题目链接:AreaoftheDevil算不在题目说的区域内的面积,直接算是比较麻烦的,这里给一个朋友直接算画的图,其实画出区域以后也算好算,当然官解提到的容斥去算更好写。一共有五个空余的区域,我们考虑这五个区域怎么计算,图一是直接画出的所有区域的并集,图二则是五角星处于边界情况时,图......
  • [ARC149D] 的题解
    思路很巧妙,首先,很明显,数轴上关于原点对称的一个点对,不论移动了多少次,都任然是对称的。再看眼数据范围,发现其实点分布的比较紧,考虑直接将所有点看做一个整体(数轴上一个线段),然后依次移动。关键的是,若这个整体横跨了原点的话,那么在原点的点就有答案了,对于剩下的部分,设在正半轴、负......
  • Codeforces 1004B Sonya and Exhibition 题解
    题目简述让你构造一个长度为$n$的$01$字符串。一个区间的价值为其中$0$的数量乘以$1$的数量,给出$m$个区间,最大化它们的价值之和。题目分析设区间$[l,r]$中$1$有$x$个,$0$有$y$个,当$x$和$y$最接近的时候,$x\timesy$最大,此结论可以用二次函数进行证明。......
  • AT_arc042_c的题解
    (一)非常妙的DP题,可惜被翻译毁了。题意:你有一堆零食,每个零食有两个值\(a_i\)和\(b_i\)。要求选出集合\(S\),使\(\sum_{i\inS}a_i-\min_{i\inS}a_i\lep\),求最大的\(\sum_{i\inS}b_i\)。一眼DP。先将\(a_i\)从小到大排序,每次循环更新\(dp_0\)的值为\(\max......
  • P10447 最短 Hamilton 路径 题解
    P10447最短Hamilton路径题解题目传送门题意:给定一张有向带权图(\(n\le20\))求点\(0\)到点\(n-1\)的最短哈密顿路径。这是一道状压DP模板题。在状态压缩DP中,我们将一个集合压成一个二进制数。设\(f_{u,i}\)为已经走了集合\(u\)中的节点,且现在在点\(i\)的最短......