結果
問題 |
No.406 鴨等間隔の法則
|
ユーザー |
|
提出日時 | 2016-11-15 23:45:47 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 37 ms / 2,000 ms |
コード長 | 782 bytes |
コンパイル時間 | 493 ms |
コンパイル使用メモリ | 55,456 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-07 11:54:36 |
合計ジャッジ時間 | 2,083 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 29 |
ソースコード
#include "iostream" using namespace std; int N; int place[100001]; int mini=-1; int semi_min=-1; int dis; bool flag[100001] = {}; int main() { cin >> N; for (int i = 0; i < N; i++) { cin >> place[i]; if (semi_min == -1)semi_min = mini; if (mini == -1)mini = place[i]; if (mini >= place[i]) { semi_min = mini; mini = place[i]; } else if (semi_min >= place[i]) { semi_min = place[i]; } } dis = semi_min - mini; //cout << dis << min << semi_min; if (dis == 0) { cout << "NO\n"; return 0; } for (int i = 0; i < N; i++) { if ((place[i] - mini) % dis == 0&&(place[i]-mini)/dis<N) { flag[(place[i]-mini)/dis] = true; } } for (int i = 0; i < N; i++) { if (!flag[i]) { cout << "NO\n"; return 0; } } cout << "YES\n"; return 0; }