結果
問題 | No.370 道路の掃除 |
ユーザー | h_noson |
提出日時 | 2016-05-18 14:01:40 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 763 bytes |
コンパイル時間 | 907 ms |
コンパイル使用メモリ | 62,224 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-14 16:55:38 |
合計ジャッジ時間 | 1,653 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 34 |
ソースコード
#include <iostream> #include <vector> #include <algorithm> using namespace std; #define RREP(i,s,e) for (i = s; i >= e; i--) #define rrep(i,n) RREP(i,(int)(n)-1,0) #define REP(i,s,e) for (i = s; i <= e; i++) #define rep(i,n) REP(i,0,(int)(n)-1) #define INF 100000000 typedef long long ll; int main() { int i, n, m, ans; int d[10000]; cin >> n >> m; rep (i,m) cin >> d[i]; sort(d,d+m); ans = INF; rep (i,m) { if (d[i] < 0 && i+n-1 < m) { if (d[i+n-1] < 0) ans = min(ans,-d[i]); else ans = min({ans,-d[i]*2+d[i+n-1],-d[i]+d[i+n-1]*2}); } else if (d[i] >= 0 && i+n-1 < m) ans = min(ans,d[i+n-1]); } cout << ans << endl; return 0; }