結果
問題 |
No.1147 土偶Ⅱ
|
ユーザー |
|
提出日時 | 2021-02-21 16:50:43 |
言語 | Kuin (KuinC++ v.2021.9.17) |
結果 |
AC
|
実行時間 | 11 ms / 500 ms |
コード長 | 1,132 bytes |
コンパイル時間 | 2,151 ms |
コンパイル使用メモリ | 148,500 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-09-16 11:35:58 |
合計ジャッジ時間 | 2,953 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 20 |
ソースコード
func main() var n: int :: cui@inputInt() var m: int :: cui@inputInt() var data: [][]bool :: #[n, n]bool var dic: dict<int, bool> :: #dict<int, bool> for(1, m) var a: int :: cui@inputInt() var b: int :: cui@inputInt() do a :- 1 do b :- 1 do data[a][b] :: true do data[b][a] :: true end for for i(0, n - 1) for j(0, n - 1) if(!data[i][j]) skip j end if ; iとjは友達。 for k(0, n - 1) if(!data[j][k]) skip k end if ; jとkは友達。 if(data[i][k]) skip k end if ; iとkは「友達」ではない。 ; iとkは「友達の友達」。 ; ※「友達の友達」であるためには、「友達」ではないことが必要 do dic.add(i * n + k, true) do dic.add(k * n + i, true) end for end for end for var ans: int :: 0 for i(0, n - 1) for j(i + 1, n - 1) if(dic.get(i * n + j, &)) skip j end if for k(j + 1, n - 1) if(dic.get(i * n + k, &)) skip k end if if(dic.get(j * n + k, &)) skip k end if do ans :+ 1 end for end for end for do cui@print("\{ans}\n") end func