結果
問題 | No.343 手抜き工事のプロ |
ユーザー |
|
提出日時 | 2016-02-13 02:39:33 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 175 ms / 2,000 ms |
コード長 | 478 bytes |
コンパイル時間 | 116 ms |
コンパイル使用メモリ | 7,552 KB |
実行使用メモリ | 19,968 KB |
最終ジャッジ日時 | 2024-12-26 06:01:03 |
合計ジャッジ時間 | 4,098 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 27 |
コンパイルメッセージ
Syntax OK
ソースコード
N = gets.to_i L = gets.to_i xs = $stdin.read.split.map(&:to_i).reverse + [0] begin ans = 0 sum = 0 cnt = 0 for i in 0...xs.size do if i > 0 then raise "-1" if (xs[i-1] - xs[i]).abs >= L center = sum / cnt.to_f #重心 ok = true ok &&= xs[i-1] < center && center < xs[i-1] + L ok &&= xs[i] < center && center < xs[i] + L ans += 1 unless ok end sum += xs[i] + L / 2.0 cnt += 1 end puts ans rescue puts $! end