結果
問題 | 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)