91692024-02-16 18:52:53NagyLeoTestnevelés órapython3Futási hiba 7/50943ms82716 KiB
from sys import stdin, stdout
input=stdin.readline


def solv():
    N, K = map(int, input().split())
    graph = [[] for i in range(N + 1)]
    indeg = [0] * (N + 1)

    for i in range(K):
        a, b = map(int, input().split())
        graph[a].append(b)
        indeg[b] += 1

    zero = []
    #   a --> b --> 2 <-- c
    #     \-> d
    for i in range(1, N + 1):
        if indeg[i] == 0:
            zero.append(i)
    # print(parents)
    result = [zero[:]]
    seen = len(zero)
    while zero:
        tmp = []
        for i in zero:
            for j in graph[i]:
                indeg[j] -= 1
                if indeg[j] == 0:
                    tmp.append(j)
        if tmp:
            result.append(tmp[:])
            seen += len(tmp)
        zero = tmp

    # print(result,graph)
    if seen != N:
        print("0")
        return
    if len(result) == N:
        print("1")
        for i in result:
            print(*i, end=" ")
    else:
        # result=[ [1,2,3], [4,5]]
        print("2")
        for i in result:
            print(*i, end=" ")
        print()
        for i[::-1] in result:
            print(*i[::-1], end=" ")


solv()
RészfeladatÖsszpontTesztVerdiktIdőMemória
base7/50
1Elfogadva0/017ms11432 KiB
2Futási hiba0/018ms12072 KiB
3Futási hiba0/0467ms48964 KiB
4Futási hiba0/217ms12300 KiB
5Futási hiba0/317ms12420 KiB
6Futási hiba0/317ms12604 KiB
7Futási hiba0/317ms12576 KiB
8Elfogadva1/117ms12748 KiB
9Futási hiba0/317ms13116 KiB
10Futási hiba0/321ms13376 KiB
11Futási hiba0/325ms13844 KiB
12Elfogadva1/121ms13528 KiB
13Elfogadva2/225ms13944 KiB
14Futási hiba0/320ms13452 KiB
15Elfogadva1/1462ms47532 KiB
16Futási hiba0/3365ms55600 KiB
17Futási hiba0/5224ms66892 KiB
18Futási hiba0/1555ms80504 KiB
19Elfogadva2/2458ms48740 KiB
20Futási hiba0/3943ms82348 KiB
21Futási hiba0/4757ms82716 KiB
22Futási hiba0/4767ms82616 KiB