2019.08.06模拟赛T2
题目大意:
已知三个$n$位二进制数$A$,$B$,$C$.
满足:
$A+B=C$
它们二进制位中$1$的个数分别为$a$,$b$,$c$.
求满足条件的最小的$C$.
Solution
唉,又是一道随缘猜结论的题,可惜极限数据卡掉了我一个点,开大数组就A了.....
通过$n \leq 10$的打表,我们发现所有的最优解中都有一种情况是$A$的二进制位的$1$是连续一段。
事实上,真的就是这样的!
设$t=a+b-c$,显然,$t$表示加法过程中进位的次数。
我们设$A$的$a$个$1$是连续的,然后在$B$中添加$b$个$1$,使得其刚好进位了$t$次(这里$a$个一后面可能有后导$0$)。
然后要分两种情况讨论。
$1.a\geq t$
$A:00001111\cdots11$
那么$B$在填$1$的时候,就不能填在$A$中最后一个$1$的位置,因为那样进位次数就会超过$t$.
所以第一个$1$应该填在这里,且$B$的前面也只能是$0$,否则相加时还会继续进位:
$A:0000\underbrace{111\cdots1}_{t}1111\cdots$
$B:$ $0$ $10000\cdots$
那么,剩下的那些$1$,就可以填在中间的位置,直到填满为止,这样就保证了$C$的尽量小。
如果中间还没填满,那就可以完事了。
接着考虑中间填满的情况,而且$B$中还有$1$没填:
$A:0000\underbrace{11111\cdots1}_{t}1111\cdots$
$B:$ $011111\cdots10000\cdots$
这里$B$还有两种可以填的地方,前面或后面。
事实上,通过推一推式子,我们发现剩下的$1$放在$B$的后面,然后$A$的后面补$0$才可以使$C$最小。
具体来说,就是设$x$为$B$中放后面的$1$的个数,然后求出$C$关于$x$的函数$f(x)$,然后发现$x$越大,$C$就越小,因此应该剩下的$1$全放在后面。
举个例子,$a=4,b=4,c=6,t=2$,构造出来应该是这样的:
$A:0111100$
$B:0110011$
$C:1101111$
$2.a<t$
这时为了使进位次数刚好为$t$次,所以$B$的首个$1$应填在$A$中最后一个$1$的位置。
然后为凑齐$t$次,还得在前面补$1$,像这样:
$A:000\cdots011111\cdots11$
$B:0000111\cdots000\cdots1$
接下来的话同理,$B$中剩下的$1$先填在中间的空位,若未填满则结束,否则$1$放在后面,同时$A$在后面补$0$。
当然,代码就很好写(毒瘤)了:
#include<bits/stdc++.h>
#define N 200010
using namespace std;
int n,a,b,c,t,ans[N],A[N],B[N];
void solve()
{
if(t>a)
{
if(t>=b)
{
for(int i = ;i<=a;i++)A[i] = ;
for(int i = ;i<=c;i++)B[i] = ;
for(int i = a+;i<=t;i++)B[i] = ;
}else
{
for(int i = ;i<=b;i++)B[i] = ;
for(int i = b-t+;i<=c;i++)A[i] = ;
}
}else
{
if(t>=b)
{
for(int i = ;i<=a;i++)A[i] = ;
for(int i = a-t+;i<=c;i++)B[i] = ;
}else
{
int x = b-t;
for(int i = x+;i<=c;i++)A[i] = ;
for(int i = ;i<=x;i++)B[i] = ;
for(int i= c-t+;i<=c;i++)B[i] = ;
}
}
for(int i = ;i<=n;i++)
{
ans[i]+=A[i]+B[i];
if(ans[i]>)ans[i]-=,ans[i+]++;
}if(ans[n+])puts("-1"),exit();
for(int i = n;i>=;i--)printf("%d",ans[i]);
}
int main()
{
scanf("%d%d%d%d",&n,&a,&b,&c);
t = a+b-c;
solve();
return ;
}
2019.08.06模拟赛T2的更多相关文章
- 2019.11.11 模拟赛 T2 乘积求和
昨天 ych 的膜你赛,这道题我 O ( n4 ) 暴力拿了 60 pts. 这道题的做法还挺妙的,我搞了将近一天呢qwq 题解 60 pts 根据题目给出的式子,四层 for 循环暴力枚举统计答案即 ...
- ZROI 19.08.06模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 今天正睿又倒闭了,从删库到跑路. 天祺鸽鸽txdy! A "不要像个小学生一样一分钟就上来问东西."--蔡老板 虽 ...
- 模拟赛T2 交换 解题报告
模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...
- ZROI 19.08.07模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "正睿从来没有保证,模拟赛的题目必须原创." "文案不是我写的,有问题找喵老师去."--蔡老师 ...
- 【2019.10.7 CCF-CSP-2019模拟赛 T2】绝对值(abs)(线段树细节题)
找规律 设\(p_i=a_{i+1}-a_i\),则答案就是\(\sum_{i=1}^{n-1}p_i\). 考虑若将\(a_i\)加上\(x\)(边界情况特殊考虑),就相当于是将\(p_{i-1}\ ...
- 【2019.8.20 NOIP模拟赛 T2】小B的树(tree)(树形DP)
树形\(DP\) 考虑设\(f_{i,j,k}\)表示在\(i\)的子树内,从\(i\)向下的最长链长度为\(j\),\(i\)子树内直径长度为\(k\)的概率. 然后我们就能发现这个东西直接转移是几 ...
- 【2019.8.15 慈溪模拟赛 T2】组合数(binom)(卢卡斯定理+高维前缀和)
卢卡斯定理 题目中说到\(p\)是质数. 而此时要求组合数向质数取模的结果,就可以用卢卡斯定理: \[C_x^y=C_{x\ div\ p}^{y\ div\ p}\cdot C_{x\ mod\ p ...
- 【2019.8.6 慈溪模拟赛 T2】树上路径(tree)(Trie)
从暴力考虑转化题意 考虑最暴力的做法,我们枚举路径的两端,然后采用类似求树上路径长度的做法,计算两点到根的贡献,然后除去\(LCA\)到根的贡献两次. 即,设\(v_i\)为\(i\)到根路径上的边权 ...
- 【2019.8.7 慈溪模拟赛 T2】环上随机点(ran)(自然算法)
简单声明 我是蒟蒻不会推式子... 所以我用的是乱搞做法... 大自然的选择 这里我用的乱搞做法被闪指导赐名为"自然算法",对于这种输入信息很少的概率题一般都很适用. 比如此题,对 ...
随机推荐
- MyBatis框架之第三篇
8.Spring与Mybatis整合 框架的整合就是软件之间的集成,它很抽象,因此在做整合之前先想好思路.规划好思路然后按照思路一步一步的做就可以实现框架的整合. 8.1.SM整合思路 8.1.1.思 ...
- JS---DOM---自定义属性引入和移除
总结:在html标签中添加的自定义属性, 如果想要获取这个属性的值, 需要使用getAttribute("自定义属性的名字")才能获取这个属性的值 html标签中有没有什么自带的属 ...
- springboot传值踩坑
由于我现在写的项目都是前后端分离的,前端用的是vue,后端springboot,于是前后端传值的问题就是一个比较重要的问题,为此我还特意去学了一下vue的传值,其实就是用一个axios组件,其实就是基 ...
- windows中常见后门持久化方法总结
转自:https://www.heibai.org/category-13.html 前言 当我们通过各种方法拿到一个服务器的权限的时候,我们下一步要做的就是后渗透了,而后门持久化也是我们后渗透很重要 ...
- Cesium专栏-气象要素(温度、降水)色斑图制作
Cesium Cesium 是一款面向三维地球和地图的,世界级的JavaScript开源产品.它提供了基于JavaScript语言的开发包,方便用户快速搭建一款零插件的虚拟地球Web应用,并在性能,精 ...
- Hazelcast介绍
Hazelcast介绍 什么时侯需要用例 内存中分布式计算 场景分布式消息 特性 全景 Distributed Maps 一个结点中分区 Hazelcast中的分片也称为分区,Hazelcast默认2 ...
- 【使用篇二】Quartz自动化配置集成(17)
出处:https://www.jianshu.com/p/49133c107143 定时任务在企业项目比较常用到,几乎所有的项目都会牵扯该功能模块,定时任务一般会处理指定时间点执行某一些业务逻辑.间隔 ...
- 剑指Offer-42.和为S的两个数字(C++/Java)
题目: 输入一个递增排序的数组和一个数字S,在数组中查找两个数,使得他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 输出描述: 对应每个测试案例,输出两个数,小的先输出. 分析: ...
- 2019阿里天猫团队Java高级工程师面试题之第三面
2019阿里天猫团队Java高级工程师面试题之第一面 2019阿里天猫团队Java高级工程师面试题之第二面 1.说说MySQL的锁并发?加锁的机制是什么? https://www.cnblogs.co ...
- 基于V7的新版RL-USB V6.X + RL-FlashFS V6.X模板,操作CLASS10的SD卡速度12-15MB/S,含RTX5和FreeRTOS两版
说明: 1.如果需要RL-USB源码的话,将DAPLink(CMSIS-DAP)里面的USB代码导出来即可,DAPLink开源了RL-USB的Device代码. 也可以反过来,在工程模板的基 ...