結果
| 問題 |
No.466 ジオラマ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2017-04-08 04:04:14 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 56 ms / 2,000 ms |
| コード長 | 1,577 bytes |
| コンパイル時間 | 289 ms |
| コンパイル使用メモリ | 12,672 KB |
| 実行使用メモリ | 11,776 KB |
| 最終ジャッジ日時 | 2024-07-16 04:55:59 |
| 合計ジャッジ時間 | 6,857 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 83 |
ソースコード
def solve(A, B, C, D):
'''
入力値
A: 0 から到達できる頂点の個数(0を含む)
B: 1 から到達できる頂点の個数(1を含む)
C: 0 からも、1 からも到達できる頂点の個数
D: 辺の数の上限
'''
a = A - C
b = B - C
if a == b == 0:
N = M = A
if N >= 2 and M <= D:
print(N, M)
Es = list(range(N)) + [0]
printEs(Es)
return
elif C == 0:
N = A + B
M = N - 2
if M <= D:
print(N, M)
Es = [0] + list(range(2, a + 1))
printEs(Es)
Es = [1] + list(range(a + 1, N))
printEs(Es)
return
elif a == 0:
N = B
M = N - 1
if M <= D:
print(N, M)
Es = list(range(1, b + 1)) + [0] + list(range(b + 1, N))
printEs(Es)
return
elif b == 0:
N = A
M = N - 1
if M <= D:
print(N, M)
Es = [0] + list(range(2, a + 1)) + [1] + list(range(a + 1, N))
printEs(Es)
return
else:
N = C + a + b
M = N - 1
v = a + b
if M <= D:
print(N, M)
Es = [0] + list(range(2, a + 1)) + [v]
printEs(Es)
Es = [1] + list(range(a + 1, N))
printEs(Es)
return
print(-1)
def printEs(Es):
for a, b in zip(Es, Es[1:]):
print(a, b)
A, B, C, D = map(int, input().split())
solve(A, B, C, D)