CF1237H Balanced Reversals
首先可以将相邻的两个点分到一个组中
特判无解的情况:
00
的数量不相等或11
的数量不相等若
10
的数量相等(此时01
的数量也相等,因为知道10
的数量后01
的数量就确定了,\(cnt_{01}=\frac{n}{2}-cnt_{00}-cnt{11}-cnt{10}\)),可以发现这一规律:
11
00
10
01
\(\mathop{\Rightarrow}\limits^{4,6}\) 01
11
00
10
,也就是说若想将某一组点放到队首并且此时除了这一组点的顺序是反的其他点的顺序照旧,只需进行两次操作,\(x-1,x+1\)(设\(x\)为当前这一组点的第一个的下标)
根据此规律,我们可以先构造出一个与所求序列刚好反过来的序列,最后再将构造出的这个序列翻一遍即可。为了节省次数,可以只处理前\(n-2\)个字符,因为保证所有所求序列中的点对在初始序列中都出现过,所以最后剩下这一点对一定就是所求序列末尾的点对(刚好对应上且顺序相同),于是最后的翻转就变成了翻转前\(n-2\)个字符
- 若不相等,就先变成相等的再解决
\(bel=cnt_{01}-cnt_{10}\)
若相等,一定有\(bel_a==bel_b\),若没有,设我们翻转\(a\)的前缀\(p\)可以使得\(bel_{a'}==bel_b\),则可以列出式子\(bel_{a'}=bel_a-2*bel_p=bel_b\ \ \ \ \Rightarrow\ \ \ \ bel_p=\frac{bel_a-bel_b}{2}\),可以通过分类\(cnt_{01}+cnt_{10}\)以及其对应的\(cnt_{01}\)与\(cnt_{10}\)的奇偶来讨论证明\(bel_a\)与\(bel_b\)的奇偶性相同
所以,枚举\(a\)的前缀求满足条件的前缀即可
但不一定是通过翻转\(a\)来使得相等,若翻转\(a\),需要\(|bel_a|\geqslant|bel_b|\),因为可以发现\(a\)的某一前缀的\(bel\)一定是其上一个前缀的\(bel\)值\(\pm1/0\)得到,也就是说从\(0\)到\(bel_a\)间的数(不包含0,包含\(bel_a\))一定是\(a\)的某一前缀的\(bel\),在这种情况下得到的\(bel_p\)一定是从\(0\)到\(bel_a\)间的某一个数(不包含0,包含\(bel_a\)),可以通过分类正负的方法证明
同理,若\(|bel_a|\leqslant|bel_b|\),则是翻转\(b\),此时\(bel_p=\frac{bel_b-bel_a}{2}\)
若翻转\(a\),则就是初始序列在一开始就先翻转;若翻转\(b\),则是初始序列所有的翻转已完成后再翻转
#include<bits/stdc++.h>
using namespace std;
const int N=4005;
int n,bal_a,bal_b,bal0,bal1,ans[N],cnt,flag;
string a,b;
void rever(string &a,int r){ for(int i=0;r-i>i;++i) swap(a[i],a[r-i]); }
void rs(string &a,int t){
int now=0;
for(int i=0;i<n;i+=2){
if(a[i]=='0'&&a[i+1]=='1') ++now;
if(a[i]=='1'&&a[i+1]=='0') --now;
if(now==t){
flag=i+2,rever(a,i+1);
break;
}
}
}
int main(){
int T;scanf("%d",&T);
while(T--){
cin>>a,cin>>b,cnt=flag=bal_a=bal_b=bal0=bal1=0;
n=a.size();
for(int i=0;i<n;i+=2){
if(a[i]=='0'&&a[i+1]=='1') ++bal_a;
if(a[i]=='1'&&a[i+1]=='0') --bal_a;
if(a[i]=='0'&&a[i+1]=='0') ++bal0;
if(a[i]=='1'&&a[i+1]=='1') ++bal1;
if(b[i]=='0'&&b[i+1]=='1') ++bal_b;
if(b[i]=='1'&&b[i+1]=='0') --bal_b;
if(b[i]=='0'&&b[i+1]=='0') --bal0;
if(b[i]=='1'&&b[i+1]=='1') --bal1;
}
if(bal0||bal1){ printf("-1\n"); continue; }
if(bal_a-bal_b){
if(abs(bal_a)>=abs(bal_b)) rs(a,(bal_a-bal_b)/2),ans[++cnt]=flag,flag=0;
else rs(b,(bal_b-bal_a)/2);
}
for(int i=0;i<n-2;i+=2)
for(int j=i;j<n;j+=2)
if(b[i]==a[j]&&b[i+1]==a[j+1]){
(j)&&(ans[++cnt]=j),ans[++cnt]=j+2;
rever(a,j-1),rever(a,j+1);
break;
}
printf("%d\n",cnt+(n-2?1:0)+(flag?1:0));
for(int i=1;i<=cnt;++i) printf("%d ",ans[i]);
if(n-2) printf("%d ",n-2);
if(flag) printf("%d",flag);
printf("\n");
}
return 0;
}
CF1237H Balanced Reversals的更多相关文章
- Leetcode 笔记 110 - Balanced Binary Tree
题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...
- CCI4.4/LintCode Balanced Binary Tree, Binary Tree, Binary Search Tree
Binary Tree: 0到2个子节点; Binary Search Tree: 所有左边的子节点 < node自身 < 所有右边的子节点: 1. Full类型: 除最下面一层外, 每一 ...
- 110.Balanced Binary Tree Leetcode解题笔记
110.Balanced Binary Tree Given a binary tree, determine if it is height-balanced. For this problem, ...
- [Leetcode][JAVA] Minimum Depth of Binary Tree && Balanced Binary Tree && Maximum Depth of Binary Tree
Minimum Depth of Binary Tree Given a binary tree, find its minimum depth. The minimum depth is the n ...
- LeetCode - Balanced Binary Tree
题目: Given a binary tree, determine if it is height-balanced. For this problem, a height-balanced bin ...
- HDOJ 3709 Balanced Number
数位DP... Balanced Number Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65535/65535 K (Java ...
- [HDU3709]Balanced Number
[HDU3709]Balanced Number 试题描述 A balanced number is a non-negative integer that can be balanced if a ...
- 【leetcode】Balanced Binary Tree(middle)
Given a binary tree, determine if it is height-balanced. For this problem, a height-balanced binary ...
- [USACO07MAR]黄金阵容均衡Gold Balanced L…(洛谷 1360)
题目描述 Farmer John's N cows (1 ≤ N ≤ 100,000) share many similarities. In fact, FJ has been able to na ...
- poj 3264:Balanced Lineup(线段树,经典题)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 32820 Accepted: 15447 ...
随机推荐
- Typora图床上传配置:PicGo+Gitee 不完全指南
每次写Markdown都要手动传图,再复制链接到Typora里,这样比较繁琐. 设置好图床,搭配PicGo,写作时直接剪贴图片到Typora,就能实现自动上传,这样就方便很多. Gitee配置: 许多 ...
- 重新整理 .net core 实践篇 ———— linux上性能排查 [外篇]
前言 该文的前置篇为: https://www.cnblogs.com/aoximin/p/16839830.html 本文介绍性能排查. 正文 上一节是出现错误了,如何去排查具体问题. 这一节介绍一 ...
- python 总是忘函数
sorted sorted()函数对所有可迭代对象进行操作,返回的是一个新列表:列表的list方法只对列表有效,且不生成新的列表. # 对成绩升序排列,名字降序排列 d1 = [{'name':'al ...
- 【深入浅出 Yarn 架构与实现】2-2 Yarn 基础库 - 底层通信库 RPC
RPC(Remote Procedure Call) 是 Hadoop 服务通信的关键库,支撑上层分布式环境下复杂的进程间(Inter-Process Communication, IPC)通信逻辑, ...
- 【题解】CF631B Print Check
题面传送门 解决思路: 首先考虑到,一个点最终的情况只有三种可能:不被染色,被行染色,被列染色. 若一个点同时被行.列染色多次,显示出的是最后一次被染色的结果.所以我们可以使用结构体,对每一行.每一列 ...
- C++ 中指针常量、指向常量的指针、引用类型的常量
命题1. 在C++ 中 const T a 与 T const a 是一样的, 表示a是一个T类型的常量. 测试: 一. 形参定义为引用类型的常量 在函数传参时,形参若定义为 const T& ...
- 2022春每日一题:Day 14
题目:字符串归类 发现字符串长度总数不大,因此把每个字符串有的字母分离,存放到桶中,再枚举合并即可,时间复杂度O(len) 赛时代码: #include <cstdio> #include ...
- 手把手,完整的从0搭建vite-vue3-ts项目框架:配置less+svg+pinia+vant+axios
项目同步git:https://gitee.com/lixin_ajax/vue3-vite-ts-pinia-vant-less.git 为避免赘述,过于基础的点会直接省略或贴图,比如创建文件夹/文 ...
- 【OpenStack云平台】Packmaker 集群
个人名片: 因为云计算成为了监控工程师 个人博客:念舒_C.ying CSDN主页️:念舒_C.ying Packmaker 集群 1.1 安装软件包 1.2 Corosync 基本配置 1.3 启 ...
- css初始化收集
页面元素样式初始化 * { margin: 0; padding: 0; box-sizing: border-box; } html { font-size: 100px; } /* 去掉a链接的文 ...