結果
問題 | No.2247 01 ZigZag |
ユーザー |
![]() |
提出日時 | 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)