結果
| 問題 |
No.1623 三角形の制作
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-07-23 22:00:53 |
| 言語 | D (dmd 2.109.1) |
| 結果 |
AC
|
| 実行時間 | 84 ms / 2,000 ms |
| コード長 | 627 bytes |
| コンパイル時間 | 1,609 ms |
| コンパイル使用メモリ | 176,284 KB |
| 実行使用メモリ | 16,812 KB |
| 最終ジャッジ日時 | 2024-06-22 11:56:15 |
| 合計ジャッジ時間 | 3,657 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 19 |
ソースコード
import std;
int MAX = 3 * 10 ^^ 3;
void main(){
int n = readln.chomp.to!int;
auto r = readln.split.to!(int[]);
auto g = readln.split.to!(int[]);
auto b = readln.split.to!(int[]);
auto rcount = new ulong[MAX + 1];
auto gcount = new ulong[MAX + 1];
auto bsum = new ulong[MAX + 1];
foreach(v; r){
rcount[v] += 1;
}
foreach(v; g){
gcount[v] += 1;
}
foreach(v; b){
bsum[v] += 1;
}
for(auto i = 1; i <= MAX; i++){
bsum[i] += bsum[i-1];
}
auto result = 0UL;
for(auto i = 1; i <= MAX; i++){
for(auto j = 1; j <= i; j++){
result += rcount[i] * gcount[j] * (bsum[i] - bsum[i-j]);
}
}
result.writeln;
}