传送门

题意: 给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 构造 + 细节相关推荐

  1. Codeforces Round #704 (Div. 2)-A. Three swimmers-题解

    目录 Codeforces Round #704 (Div. 2)-A. Three swimmers Problem Description Input Output Sample Input Sa ...

  2. Codeforces Round #704 (Div. 2)-C. Maximum width-题解

    目录 Codeforces Round #704 (Div. 2)-C. Maximum width Problem Description Input Output Sample Input Sam ...

  3. Codeforces Round #704 (Div. 2)-B. Card Deck-题解

    目录 Codeforces Round #704 (Div. 2)-B. Card Deck Problem Description Input Output Sample Input Sample ...

  4. Codeforces Round #453 (Div. 1) D. Weighting a Tree 构造 + dfs树

    传送门 文章目录 题意: 思路: 题意: 给你一颗nnn个点的图,每个点都有一个点权cic_ici​,要求你给每个边赋一个权值kik_iki​,要求对于每个点与他相连的边的权值之和等于这个点的点权ci ...

  5. 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 ...

  6. Codeforces Round #592 (Div. 2) G. Running in Pairs 构造(水)

    传送门 文章目录 题意: 思路: 题意: 思路: 史上最水GGG题,没有之一. 考虑最小的情况如何构造,显然就是让a,ba,ba,b都1−n1-n1−n依次排列即可,这样的最小值为n∗(n+1)2\f ...

  7. Codeforces Round #632 (Div. 2) E. Road to 1600 构造好题

    传送门 文章目录 题意: 思路 题意: 直接白嫖 思路 首先不难发现,n≤2n\le2n≤2的时候是无解的. 现在我们来构造n=3n=3n=3的情况,通过打表可以发现如下矩阵是符合题目要求的: 179 ...

  8. Codeforces Round #631 (Div. 2) C. Dreamoon Likes Coloring 构造

    传送门 文章目录 题意: 思路: 题意: 思路: 针灸思维不行,数据结构来凑呗. 一开始做的时候想简单了,一直wawawa,后来想到了hackhackhack样例,开始换思路构造,结果死活想不到O(m ...

  9. Codeforces Round #704 (Div. 2)(A ~ E)5题全 超高质量题解【每日亿题2 / 23】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 目录 A.Three swimmers B.Card Deck C.Maximum width D.G ...

最新文章

  1. c++窗口管理系统是什么_优秀的食堂管理系统让你对校园生活更充满希望
  2. 串口基础类库(WIN32)异步通信 _COM_H 源代码
  3. SpringBoot24 SpringDataJPA环境搭建、实体类注解、关联查询
  4. GRE写作-学生选择有助于就业的课程or根据兴趣选课?
  5. oracle 自定义 聚合函数
  6. html 登陆sql server,jsp实现注册与登录页面+sqlsever2008
  7. shell 文件路径有空格_Python学习第57课-shell入门之基本简单命令(一)
  8. SpringBoot实战:整合Redis、mybatis,封装RedisUtils工具类等(附源码)
  9. 2021年中国以太网测试设备市场趋势报告、技术动态创新及2027年市场预测
  10. Vue自定义组件封装及使用Excel
  11. 恢复初始快捷键_如何将Windows10系统还原初始状态
  12. .net HTML编码解析
  13. 安全专家:70GB财务数据被僵尸网络盗窃
  14. idea中修改git账号和密码
  15. linux的视频格式转换软件,工具盘点:必备的Linux视频转换工具(1)
  16. 2021年中国直播电商投融资情况及行业发展中存在的问题、发展趋势和对策分析[图]
  17. python写梦幻西游手游脚本_AirtestIDE实践一:梦幻西游手游师门任务自动化
  18. 流媒体与实时计算,Netflix公司Druid应用实践
  19. GameCenter Achievement相关问题
  20. JAVA医院预约挂号系统毕业设计 开题报告

热门文章

  1. 每年通过率仅1%的“天才考试”,中国到底应不应该学?
  2. 有些人还活着,被你一按就死了。。 | 今日最佳
  3. 从数学入手,3招打破机器学习的边界
  4. 入门 | 机器学习第一课:决策树学习概述与实现
  5. 计算机如何实现共享接入,局域网内电脑实现共享设置方法
  6. 理请求时出现未知错误.服务器返回的状态码为: 500,react-native
  7. qt 安装mysql_qt 安装mysql数据库
  8. python使用opencv查找轮廓_Python+opencv学习记录20:轮廓发现,Pythonopencv
  9. php字符串赋值给变量,JavaScript-如何将一个PHP字符串安全赋值给Javascript变量(包含引号和换行符的)...
  10. 数据科学与python——Pandas统计分析基础(数据堆叠+数据清洗)