結果
問題 | No.5016 Worst Mayor |
ユーザー |
![]() |
提出日時 | 2023-04-29 15:10:54 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 257 ms / 2,000 ms |
コード長 | 2,859 bytes |
コンパイル時間 | 859 ms |
コンパイル使用メモリ | 87,256 KB |
実行使用メモリ | 94,780 KB |
スコア | 9,416,171,969 |
平均クエリ数 | 400.00 |
最終ジャッジ日時 | 2023-04-29 15:11:12 |
合計ジャッジ時間 | 15,602 ms |
ジャッジサーバーID (参考情報) |
judge12 / judge11 |
純コード判定しない問題か言語 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 50 |
ソースコード
def calc_cost():a = int(10 ** 7 / supporter ** 0.5 + 2)while supporter * a ** 2 > 10 ** 14:a -= 1return adef execute(key, param = None):global supporter, moneyif key == 1:print(1, *param)money -= costelif key == 2:print(2)supporter += 1elif key == 3:print(3)money += 50000else:assert 0, "Execute Key Error"from random import randrangeDEBUG = 0N, T = map(int, input().split())supporter = 1money = 10 ** 6for _ in range(N):a, b, c, d = map(int, input().split())M = 14done = [[[0] * M for _ in range(M - 1)], [[0] * (M - 1) for _ in range(M)]]# priority = [(0, 6, 6), (1, 6, 6), (0, 6, 7)]priority = [(0, 6, 0), (1, 6, 0), (0, 6, 1), (1, 7, 1), (0, 6, 2), (1, 6, 2), (0, 6, 3), (1, 7, 3), (0, 6, 4), (1, 6, 4), (0, 6, 5), (1, 7, 5), (0, 6,6), (1, 6, 6), (0, 6, 7), (1, 7, 7), (0, 6, 8), (1, 6, 8), (0, 6, 9), (1, 7, 9), (0, 6, 10), (1, 6, 10), (0, 6, 11), (1, 7, 11), (0, 6, 12), (1, 6, 12), (0, 6, 13), (0, 0, 0), (1, 0, 0), (0, 0, 1), (1, 1, 1), (0, 0, 2), (1, 0, 2), (0, 0, 3), (1, 1, 3), (0, 0, 4), (1, 0, 4), (0, 0, 5), (1, 1,5), (0, 0, 6), (1, 0, 6), (0, 0, 7), (1, 1, 7), (0, 0, 8), (1, 0, 8), (0, 0, 9), (1, 1, 9), (0, 0, 10), (1, 0, 10), (0, 0, 11), (1, 1, 11), (0, 0,12), (1, 0, 12), (0, 0, 13), (0, 12, 0), (1, 12, 0), (0, 12, 1), (1, 13, 1), (0, 12, 2), (1, 12, 2), (0, 12, 3), (1, 13, 3), (0, 12, 4), (1, 12, 4), (0, 12, 5), (1, 13, 5), (0, 12, 6), (1, 12, 6), (0, 12, 7), (1, 13, 7), (0, 12, 8), (1, 12, 8), (0, 12, 9), (1, 13, 9), (0, 12, 10), (1, 12, 10), (0, 12, 11), (1, 13, 11), (0, 12, 12), (1, 12, 12), (0, 12, 13), (0, 1, 7), (1, 2, 6), (0, 2, 6), (1, 3, 6), (0, 3, 7), (1, 4, 6), (0, 4, 6),(1, 5, 6), (0, 5, 7), (0, 7, 6), (1, 8, 6), (0, 8, 7), (1, 9, 6), (0, 9, 6), (1, 10, 6), (0, 10, 7), (1, 11, 6), (0, 11, 6), (0, 1, 1), (1, 2, 0),(0, 2, 0), (1, 3, 0), (0, 3, 1), (1, 4, 0), (0, 4, 0), (1, 5, 0), (0, 5, 1), (0, 7, 0), (1, 8, 0), (0, 8, 1), (1, 9, 0), (0, 9, 0), (1, 10, 0), (0, 10, 1), (1, 11, 0), (0, 11, 0), (0, 1, 13), (1, 2, 12), (0, 2, 12), (1, 3, 12), (0, 3, 13), (1, 4, 12), (0, 4, 12), (1, 5, 12), (0, 5, 13), (0,7, 12), (1, 8, 12), (0, 8, 13), (1, 9, 12), (0, 9, 12), (1, 10, 12), (0, 10, 13), (1, 11, 12), (0, 11, 12)][::-1]for q in range(T):u, v = map(int, input().split())cost = calc_cost()if DEBUG:print("cost =", cost, "u, v =", u, v)if u >= cost:if cost > (T - 1 - q) * 4000111110:execute(3)continueif priority:t, i, j = priority.pop()done[t][i][j] = 1if t == 0:ni, nj = i + 1, jelse:ni, nj = i, j + 1execute(1, (i + 1, j + 1, ni + 1, nj + 1))else:execute(3)else:execute(2)