結果
問題 |
No.118 門松列(2)
|
ユーザー |
|
提出日時 | 2020-07-31 00:25:40 |
言語 | Kuin (KuinC++ v.2021.9.17) |
結果 |
AC
|
実行時間 | 49 ms / 5,000 ms |
コード長 | 856 bytes |
コンパイル時間 | 2,800 ms |
コンパイル使用メモリ | 147,568 KB |
実行使用メモリ | 6,944 KB |
最終ジャッジ日時 | 2024-09-16 11:16:26 |
合計ジャッジ時間 | 4,106 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge6 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 26 |
ソースコード
func main() var n: int :: cui@inputInt() var a: []int :: #[n]int for i(0, n - 1) do a[i] :: cui@inputInt() end for var mp: dict<int, int> :: #dict<int, int> for i(0, n - 1) do mp.add(a[i], mp.get(a[i], &) + 1) end for var ans: int :: 0 var keys: []int block var keyList: List :: #List class List() +var li: list<int> *func ctor() do me.li :: #list<int> end func end class do mp.forEach(callback, keyList $ kuin@Class) func callback(key: int, value: int, data: kuin@Class): bool do(data $ List).li.add(key) ret true end func do keys :: keyList.li.toArray() end block for i(0, ^keys - 1) for j(i + 1, ^keys - 1) for k(j + 1, ^keys - 1) do ans :+ mp.get(keys[i], &) * mp.get(keys[j], &) * mp.get(keys[k], &) end for end for end for do ans :% 10 ^ 9 + 7 do cui@print("\{ans}\n") end func