結果
| 問題 |
No.1147 土偶Ⅱ
|
| ユーザー |
brthyyjp
|
| 提出日時 | 2021-01-26 15:37:06 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 84 ms / 500 ms |
| コード長 | 633 bytes |
| コンパイル時間 | 305 ms |
| コンパイル使用メモリ | 82,552 KB |
| 実行使用メモリ | 75,516 KB |
| 最終ジャッジ日時 | 2024-06-23 15:02:53 |
| 合計ジャッジ時間 | 2,660 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 20 |
ソースコード
n, m = map(int, input().split())
INF =10**18
d = [[INF]*n for i in range(n)]
for i in range(n):
d[i][i] = 0
for i in range(m):
a, b = map(int, input().split())
a, b = a-1, b-1
d[a][b] = 1
d[b][a] = 1
def warshal_floyd(d):
n = len(d)
for k in range(n):
for i in range(n):
for j in range(n):
d[i][j] = min(d[i][j], d[i][k]+d[k][j])
return d
d = warshal_floyd(d)
ans = n*(n-1)*(n-2)//6
for i in range(n-2):
for j in range(i+1, n-1):
for k in range(j+1, n):
if d[i][j] == 2 or d[j][k] == 2 or d[k][i] == 2:
ans -= 1
print(ans)
brthyyjp