結果

問題 No.488 四角関係
ユーザー kjnhokjnho
提出日時 2017-02-24 23:02:59
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
WA  
実行時間 -
コード長 1,038 bytes
コンパイル時間 174 ms
コンパイル使用メモリ 10,932 KB
実行使用メモリ 8,420 KB
最終ジャッジ日時 2023-08-30 23:42:36
合計ジャッジ時間 6,977 ms
ジャッジサーバーID
(参考情報)
judge14 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 AC 2,460 ms
8,308 KB
testcase_09 AC 17 ms
8,212 KB
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 AC 16 ms
8,256 KB
testcase_17 AC 16 ms
8,308 KB
testcase_18 AC 16 ms
8,408 KB
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

import itertools
def main():
    global mapping
    N, M = map(int, input().split())

    mapping = [[False]*N for n in range(N)]
    for m in range(M):
        a, b = map(int, input().split())
        mapping[a][b] = True
        mapping[b][a] = True

    # print(mapping)

    count = 0
    for c in itertools.combinations(range(N), 4):
        if check(c):
            # print(c)
            count += 1

    print(count)

def check(p):
    stack = [(p[0], 1)]
    count = 0
    while len(stack) != 0:
        now, num = stack.pop()
        for i in range(4):
            if connected(now, p[i]):
                if num + 1 == 4:
                    count += 1
                else:
                    stack.append((p[i], num + 1))
    if count == 1:
        return True
    else:
        return False


def connected(x,y):
    if mapping[x][y] or mapping[y][x]:
        return True
    else:
        return False


if __name__ == "__main__":  # {{{
    try:
        import test
        test.test()
    except:
        main()  # }}}


0