結果

問題 No.241 出席番号(1)
ユーザー burita083burita083
提出日時 2021-06-17 01:59:33
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 2,486 bytes
コンパイル時間 2,953 ms
コンパイル使用メモリ 82,272 KB
実行使用メモリ 210,980 KB
最終ジャッジ日時 2025-01-01 17:11:05
合計ジャッジ時間 24,613 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 52 ms
74,240 KB
testcase_01 AC 50 ms
210,980 KB
testcase_02 AC 58 ms
76,132 KB
testcase_03 AC 51 ms
209,956 KB
testcase_04 AC 54 ms
75,384 KB
testcase_05 AC 52 ms
66,920 KB
testcase_06 AC 51 ms
66,948 KB
testcase_07 AC 50 ms
67,504 KB
testcase_08 AC 50 ms
67,156 KB
testcase_09 AC 49 ms
66,944 KB
testcase_10 AC 51 ms
68,080 KB
testcase_11 WA -
testcase_12 AC 50 ms
67,348 KB
testcase_13 AC 59 ms
68,088 KB
testcase_14 AC 57 ms
70,852 KB
testcase_15 AC 58 ms
69,260 KB
testcase_16 AC 50 ms
76,548 KB
testcase_17 AC 49 ms
67,124 KB
testcase_18 AC 50 ms
68,060 KB
testcase_19 AC 50 ms
66,740 KB
testcase_20 AC 51 ms
67,492 KB
testcase_21 AC 58 ms
67,024 KB
testcase_22 AC 52 ms
67,220 KB
testcase_23 AC 54 ms
69,180 KB
testcase_24 AC 55 ms
69,372 KB
testcase_25 AC 69 ms
71,144 KB
testcase_26 AC 60 ms
70,864 KB
testcase_27 WA -
testcase_28 AC 57 ms
70,168 KB
testcase_29 AC 60 ms
72,036 KB
testcase_30 TLE -
testcase_31 TLE -
権限があれば一括ダウンロードができます

ソースコード

diff #

# 最大流問題
from collections import deque
INF = float("inf")
TO = 0;  CAP = 1;  REV = 2
class Dinic:
    def __init__(self, N):
        self.N = N
        self.V = [[] for _ in range(N)]  # to, cap, rev
        # 辺 e = V[n][m] の逆辺は V[e[TO]][e[REV]]
        self.level = [0] * N

    def add_edge(self, u, v, cap):
        self.V[u].append([v, cap, len(self.V[v])])
        self.V[v].append([u, 0, len(self.V[u])-1])

    def add_edge_undirected(self, u, v, cap):  # 未検証
        self.V[u].append([v, cap, len(self.V[v])])
        self.V[v].append([u, cap, len(self.V[u])-1])

    def bfs(self, s: int) -> bool:
        self.level = [-1] * self.N
        self.level[s] = 0
        q = deque()
        q.append(s)
        while len(q) != 0:
            v = q.popleft()
            for e in self.V[v]:
                if e[CAP] > 0 and self.level[e[TO]] == -1:  # capが1以上で未探索の辺
                    self.level[e[TO]] = self.level[v] + 1
                    q.append(e[TO])
        return True if self.level[self.g] != -1 else False  # 到達可能

    def dfs(self, v: int, f) -> int:
        if v == self.g:
            return f
        for i in range(self.ite[v], len(self.V[v])):
            self.ite[v] = i
            e = self.V[v][i]
            if e[CAP] > 0 and self.level[v] < self.level[e[TO]]:
                d = self.dfs(e[TO], min(f, e[CAP]))
                if d > 0:  # 増加路
                    e[CAP] -= d  # cap を減らす
                    self.V[e[TO]][e[REV]][CAP] += d  # 反対方向の cap を増やす
                    return d
        return 0

    def solve(self, s, g):
        self.g = g
        flow = 0
        while self.bfs(s):  # 到達可能な間
            self.ite = [0] * self.N
            f = self.dfs(s, INF)
            while f > 0:
                flow += f
                f = self.dfs(s, INF)
        return flow


N = int(input())
A = []
for i in range(N):
  A.append(int(input()))
dp = [set() for i in range(N)]
for i, x in enumerate(A):
  for j in range(N):
    if j != x:
      dp[i].add(j)

ans = -float('inf')
import random
l = []
for i in range(500000):
  st = set()
  temp = 0
  for d in dp:
    d -= st
    while True:
      if len(d) == 0:
        break
      item = random.sample(d, 1)
      if not item[0] in st:
        st.add(item[0])
        l.append(item[0])
        temp += 1
        break
  if temp == N:
    break
if len(l) < N:
  print(-1)
  exit()
for d in l:
  print(d)
0