結果
| 問題 |
No.1147 土偶Ⅱ
|
| ユーザー |
|
| 提出日時 | 2020-08-06 11:06:58 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 113 ms / 500 ms |
| コード長 | 981 bytes |
| コンパイル時間 | 180 ms |
| コンパイル使用メモリ | 82,424 KB |
| 実行使用メモリ | 77,412 KB |
| 最終ジャッジ日時 | 2024-10-11 10:13:51 |
| 合計ジャッジ時間 | 2,729 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 20 |
ソースコード
def main():
from collections import deque
n,m=map(int,input().split())
g=[[] for _ in range(n)]
for _ in range(m):
a,b=map(int,input().split())
a-=1
b-=1
g[a].append(b)
g[b].append(a)
dp=[[[False]*n for j in range(n)] for i in range(3)]
for i in range(n):
dp[0][i][i]=True
bfs=deque([i*1000+i for i in range(n)])
pop=bfs.popleft
push=bfs.append
while bfs:
v=pop()
d=v//1000000
v%=1000000
s=v//1000
cur=v%1000
if d==2:
continue
for to in g[cur]:
if dp[d+1][s][to]:
continue
dp[d+1][s][to]=True
push((d+1)*1000000+s*1000+to)
ans=n*(n-1)*(n-2)//6
for i in range(n):
for j in range(i+1,n):
for k in range(j+1,n):
if not(dp[0][i][j] or dp[1][i][j]) and dp[2][i][j]:
ans-=1
elif not(dp[0][j][k] or dp[1][j][k]) and dp[2][j][k]:
ans-=1
elif not(dp[0][k][i] or dp[1][k][i]) and dp[2][k][i]:
ans-=1
print(ans)
main()