結果
| 問題 |
No.2247 01 ZigZag
|
| コンテスト | |
| ユーザー |
FromBooska
|
| 提出日時 | 2024-03-18 17:26:12 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 1,381 ms / 2,000 ms |
| コード長 | 2,826 bytes |
| コンパイル時間 | 294 ms |
| コンパイル使用メモリ | 82,724 KB |
| 実行使用メモリ | 258,432 KB |
| 最終ジャッジ日時 | 2024-09-30 05:00:14 |
| 合計ジャッジ時間 | 12,423 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 50 |
ソースコード
# K+1グループ作る、0は先頭に0固める、1は最後に1固める
# 0個数が(K+1+1)//2以上、1個数が(K+1)//2以上あれば0始まり
# 1個数が(K+1+1)//2以上、0個数が(K+1)//2以上あれば1始まり
# K0のコーナーケースあり
N, M, K = map(int, input().split())
if K == 0:
if N==0 and M!=0:
ans = '1'*M
print(ans)
elif N!=0 and M==0:
ans = '0'*N
print(ans)
else:
print(-1)
exit()
if N>=(K+1+1)//2 and M>=(K+1)//2: #0始まり
if (K+1)%2 == 1: #0終わり
zero_group = (K+1+1)//2
one_group = zero_group-1
ans = ''
for i in range(zero_group+one_group):
if i%2 == 0: #0
if i==0:
ans += '0'
ans += '0'*(N-zero_group)
else:
ans += '0'
else: #1
if i == zero_group+one_group-2:
ans += '1'
ans += '1'*(M-one_group)
else:
ans += '1'
print(ans)
else: #1終わり
zero_group = (K+1+1)//2
one_group = zero_group
ans = ''
for i in range(zero_group+one_group):
if i%2 == 0: #0
if i==0:
ans += '0'
ans += '0'*(N-zero_group)
else:
ans += '0'
else: #1
if i == zero_group+one_group-1:
ans += '1'
ans += '1'*(M-one_group)
else:
ans += '1'
print(ans)
elif M>=(K+1+1)//2 and N>=(K+1)//2: #1始まり
if (K+1)%2 == 0: #0終わり
one_group = (K+1+1)//2
zero_group = one_group
ans = ''
for i in range(zero_group+one_group):
if i%2 == 1: #0
if i==0:
ans += '0'
ans += '0'*(N-zero_group)
else:
ans += '0'
else: #1
if i == zero_group+one_group-2:
ans += '1'
ans += '1'*(M-one_group)
else:
ans += '1'
print(ans)
else: #1終わり
one_group = (K+1+1)//2
zero_group = one_group-1
ans = ''
for i in range(zero_group+one_group):
if i%2 == 1: #0
if i==0:
ans += '0'
ans += '0'*(N-zero_group)
else:
ans += '0'
else: #1
if i == zero_group+one_group-1:
ans += '1'
ans += '1'*(M-one_group)
else:
ans += '1'
print(ans)
else:
print(-1)
FromBooska