結果
| 問題 |
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