傳送門
題意: 給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來構造出來答案?,F在解決了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 构造 + 细节的全部內容,希望文章能夠幫你解決所遇到的問題。
如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。