传送门
题意: 给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。
#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
;
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()
{
scanf("%d%d%d",&a
,&b
,&k
);if(!check()) puts("NO");return 0;
}
创作挑战赛新人创作奖励来咯,坚持创作打卡瓜分现金大奖
总结
以上是生活随笔为你收集整理的Codeforces Round #704 (Div. 2) D. Genius‘s Gambit 构造 + 细节的全部内容,希望文章能够帮你解决所遇到的问题。
如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。