Codeforces Round #704 (Div. 2) D. Genius‘s Gambit 构造 + 细节
传送门
题意: 给a,b,ka,b,ka,b,k,要求用aaa个000和bbb个111组成二进制xxx和yyy,并且x−yx-yx−y恰好有kkk个111,并且xxx和yyy不含前导零。
思路: 首先需要看到不含前导零,一开始没看见wa5了。让后一个很明显的构造,举个例子:a=4,b=2,k=3a=4,b=2,k=3a=4,b=2,k=3那么可以构造x=10∣1000x=10|1000x=10∣1000,y=10∣0001y=10|0001y=10∣0001,我把前后两部分划分开了,前面的是多出来的,我们看后面,显然可以用一个111和kkk个000来构造出来答案。现在解决了a<=ka<=ka<=k的情况,如果a>ka>ka>k呢?因为我们000的贡献考虑完了,我们可以尝试在100010001000和000100010001中加入111,可以发现在相同位置都加上111可以使最终111的个数+1+1+1。比如10∣10∣11∣010|10|11|010∣10∣11∣0和10∣00∣11∣110|00|11|110∣00∣11∣1,除去第一个竖杠,两个新竖杠之间的是我们在x=10∣1000x=10|1000x=10∣1000,y=10∣0001y=10|0001y=10∣0001的基础上加上的,二者相减即可发现最终111的个数多了222。那么现在就解决了吗?我们还漏了一点就是k=a+bk=a+bk=a+b的时候,这个时候是无解的,这个是比较容易看出来的。
让后就是构造完之后看看第一个数是否是000即可。注意多出来的如果有111一定要往开头放。
让后因为我的代码实现的缘故,需要特判一下a==0a==0a==0和b==0b==0b==0。
//#pragma GCC optimize(2)
#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<map>
#include<cmath>
#include<cctype>
#include<vector>
#include<set>
#include<queue>
#include<algorithm>
#include<sstream>
#include<ctime>
#include<cstdlib>
#define X first
#define Y second
#define L (u<<1)
#define R (u<<1|1)
#define pb push_back
#define mk make_pair
#define Mid (tr[u].l+tr[u].r>>1)
#define Len(u) (tr[u].r-tr[u].l+1)
#define random(a,b) ((a)+rand()%((b)-(a)+1))
#define db puts("---")
using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }
//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }
//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int,int> PII;const int N=1000010,mod=1e9+7,INF=0x3f3f3f3f;
const double eps=1e-6;int a,b,k;bool check()
{if(!a){if(k) return false;puts("YES");for(int i=1;i<=b;i++) printf("1"); puts("");for(int i=1;i<=b;i++) printf("1"); puts("");return true;}if(!b&&k) return false;if(!b&&!k){puts("YES");for(int i=1;i<=a;i++) printf("0"); puts("");for(int i=1;i<=a;i++) printf("0"); puts("");return true;}if(k<=a){if(b==1&&k!=0) return false;string x,y; b--; a-=k;for(int i=1;i<=k;i++) x+='0'; x+='1';y+='1'; for(int i=1;i<=k;i++) y+='0';for(int i=1;i<=b;i++) x+='1',y+='1';reverse(x.begin(),x.end());reverse(y.begin(),y.end());for(int i=1;i<=a;i++) x+='0',y+='0';if(y[0]=='0') return false;puts("YES");cout<<x<<endl;cout<<y<<endl;return true;}else if(k==a+b) return false;else{if(b==1&&k!=0) return false;string x,y; b--; b-=k-a;if(!b) return false;x+='0'; y+='1';for(int i=1;i<=k-a;i++) x+='1',y+='1';for(int i=1;i<=a-1;i++) x+='0',y+='0';x+='1'; y+='0';for(int i=1;i<=b;i++) x+='1',y+='1';reverse(x.begin(),x.end());reverse(y.begin(),y.end());if(y[0]=='0') return false;puts("YES");cout<<x<<endl;cout<<y<<endl;return true;}
}int main()
{// ios::sync_with_stdio(false);
// cin.tie(0);scanf("%d%d%d",&a,&b,&k);if(!check()) puts("NO");return 0;
}
/**/
Codeforces Round #704 (Div. 2) D. Genius‘s Gambit 构造 + 细节相关推荐
- Codeforces Round #704 (Div. 2)-A. Three swimmers-题解
目录 Codeforces Round #704 (Div. 2)-A. Three swimmers Problem Description Input Output Sample Input Sa ...
- Codeforces Round #704 (Div. 2)-C. Maximum width-题解
目录 Codeforces Round #704 (Div. 2)-C. Maximum width Problem Description Input Output Sample Input Sam ...
- Codeforces Round #704 (Div. 2)-B. Card Deck-题解
目录 Codeforces Round #704 (Div. 2)-B. Card Deck Problem Description Input Output Sample Input Sample ...
- Codeforces Round #453 (Div. 1) D. Weighting a Tree 构造 + dfs树
传送门 文章目录 题意: 思路: 题意: 给你一颗nnn个点的图,每个点都有一个点权cic_ici,要求你给每个边赋一个权值kik_iki,要求对于每个点与他相连的边的权值之和等于这个点的点权ci ...
- Codeforces Round #381 (Div. 1) A. Alyona and mex 构造
传送门 文章目录 题意: 思路: 题意: 你需要确定一个长度为nnn的数组aaa,满足给定的mmm个[l,r][l,r][l,r]限制,需要保证构造出来的aaa数组对于每个[l,r][l,r][l,r ...
- Codeforces Round #592 (Div. 2) G. Running in Pairs 构造(水)
传送门 文章目录 题意: 思路: 题意: 思路: 史上最水GGG题,没有之一. 考虑最小的情况如何构造,显然就是让a,ba,ba,b都1−n1-n1−n依次排列即可,这样的最小值为n∗(n+1)2\f ...
- Codeforces Round #632 (Div. 2) E. Road to 1600 构造好题
传送门 文章目录 题意: 思路 题意: 直接白嫖 思路 首先不难发现,n≤2n\le2n≤2的时候是无解的. 现在我们来构造n=3n=3n=3的情况,通过打表可以发现如下矩阵是符合题目要求的: 179 ...
- Codeforces Round #631 (Div. 2) C. Dreamoon Likes Coloring 构造
传送门 文章目录 题意: 思路: 题意: 思路: 针灸思维不行,数据结构来凑呗. 一开始做的时候想简单了,一直wawawa,后来想到了hackhackhack样例,开始换思路构造,结果死活想不到O(m ...
- Codeforces Round #704 (Div. 2)(A ~ E)5题全 超高质量题解【每日亿题2 / 23】
整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 目录 A.Three swimmers B.Card Deck C.Maximum width D.G ...
最新文章
- c++窗口管理系统是什么_优秀的食堂管理系统让你对校园生活更充满希望
- 串口基础类库(WIN32)异步通信 _COM_H 源代码
- SpringBoot24 SpringDataJPA环境搭建、实体类注解、关联查询
- GRE写作-学生选择有助于就业的课程or根据兴趣选课?
- oracle 自定义 聚合函数
- html 登陆sql server,jsp实现注册与登录页面+sqlsever2008
- shell 文件路径有空格_Python学习第57课-shell入门之基本简单命令(一)
- SpringBoot实战:整合Redis、mybatis,封装RedisUtils工具类等(附源码)
- 2021年中国以太网测试设备市场趋势报告、技术动态创新及2027年市场预测
- Vue自定义组件封装及使用Excel
- 恢复初始快捷键_如何将Windows10系统还原初始状态
- .net HTML编码解析
- 安全专家:70GB财务数据被僵尸网络盗窃
- idea中修改git账号和密码
- linux的视频格式转换软件,工具盘点:必备的Linux视频转换工具(1)
- 2021年中国直播电商投融资情况及行业发展中存在的问题、发展趋势和对策分析[图]
- python写梦幻西游手游脚本_AirtestIDE实践一:梦幻西游手游师门任务自动化
- 流媒体与实时计算,Netflix公司Druid应用实践
- GameCenter Achievement相关问题
- JAVA医院预约挂号系统毕业设计 开题报告
热门文章
- 每年通过率仅1%的“天才考试”,中国到底应不应该学?
- 有些人还活着,被你一按就死了。。 | 今日最佳
- 从数学入手,3招打破机器学习的边界
- 入门 | 机器学习第一课:决策树学习概述与实现
- 计算机如何实现共享接入,局域网内电脑实现共享设置方法
- 理请求时出现未知错误.服务器返回的状态码为: 500,react-native
- qt 安装mysql_qt 安装mysql数据库
- python使用opencv查找轮廓_Python+opencv学习记录20:轮廓发现,Pythonopencv
- php字符串赋值给变量,JavaScript-如何将一个PHP字符串安全赋值给Javascript变量(包含引号和换行符的)...
- 数据科学与python——Pandas统计分析基础(数据堆叠+数据清洗)