結果
問題 | No.33 アメーバがたくさん |
ユーザー | diginatu |
提出日時 | 2014-10-03 00:57:32 |
言語 | D (dmd 2.106.1) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 738 bytes |
コンパイル時間 | 1,021 ms |
コンパイル使用メモリ | 108,288 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-12 01:27:26 |
合計ジャッジ時間 | 1,819 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 1 ms
5,376 KB |
testcase_02 | AC | 1 ms
5,376 KB |
testcase_03 | AC | 1 ms
5,376 KB |
testcase_04 | AC | 1 ms
5,376 KB |
testcase_05 | AC | 1 ms
5,376 KB |
testcase_06 | AC | 1 ms
5,376 KB |
testcase_07 | AC | 2 ms
5,376 KB |
testcase_08 | AC | 1 ms
5,376 KB |
testcase_09 | AC | 1 ms
5,376 KB |
testcase_10 | AC | 1 ms
5,376 KB |
ソースコード
import std.stdio, std.string, std.conv ,std.array,std.algorithm, std.range ,std.math; void main(){ auto buf = readln().strip().split().map!(to!int)(); immutable int N = buf[0]; immutable int D = buf[1]; immutable int T = buf[2]; auto x = readln().strip().split().map!(to!int)(); auto X = x.array.sort(); long[][int] sd; foreach(long xe; X) { int r = xe % D; int modr = r<0 ? r + D : r; sd[modr] ~= (xe+10^^9)/D; } //writeln(sd); long ans = 0; foreach(long[] s; sd) { ans += s.length * (2 * T + 1); //writeln(ans); foreach(immutable int i; 0 .. s.length.to!int - 1) { if(s[i] + T >= s[i+1] - T) { ans -= s[i] + T - (s[i+1] - T) + 1; } } } writeln(ans); }