結果

問題 No.2418 情報通だよ!Nafmoくん
コンテスト
ユーザー flippergo
提出日時 2026-04-23 07:40:25
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
AC  
実行時間 433 ms / 2,000 ms
コード長 643 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 171 ms
コンパイル使用メモリ 85,704 KB
実行使用メモリ 102,784 KB
最終ジャッジ日時 2026-04-23 07:40:34
合計ジャッジ時間 7,784 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 21
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import sys
sys.setrecursionlimit(1000000)
N,M = map(int,input().split())
T = [[i,1] for i in range(2*N+1)]
def rfind(i):
    if T[i][0]==i:
        return i
    return rfind(T[i][0])
def runion(i,j):
    ri = rfind(i)
    rj = rfind(j)
    if ri==rj:return
    if T[ri][1]>=T[rj][1]:
        T[rj][0] = ri
        T[ri][1] += T[rj][1]
    elif T[ri][1]<T[rj][1]:
        T[ri][0] = rj
        T[rj][1] += T[ri][1]
for _ in range(M):
    a,b = map(int,input().split())
    runion(a,b)
visited = [0]*(2*N+1)
ans = 0
for i in range(1,2*N+1):
    ri = rfind(i)
    if visited[ri]==0:
        ans += T[ri][1]//2
        visited[ri] = 1
print(N-ans)
0