結果
問題 |
No.1834 1D Gravity
|
ユーザー |
👑 |
提出日時 | 2022-01-09 13:03:05 |
言語 | C (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 859 bytes |
コンパイル時間 | 204 ms |
コンパイル使用メモリ | 30,720 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-14 10:21:10 |
合計ジャッジ時間 | 11,085 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 10 WA * 16 |
ソースコード
#include <stdio.h> void chmax(int* a, int b) { if (*a < b) *a = b; } int main() { int i, N, m[200001], p[200001]; scanf("%d", &N); for (i = 1; i <= N; i++) { scanf("%d", &(m[i])); p[m[i]] = i; } int j, k, max[200001], len, num; for (i = 1; i <= N; i++) max[i] = m[i]; for (k = 1; k <= 1000; k++) { for (i = 1; i <= N; i++) { if (p[i] == 1) p[i] = 2; else if (p[i] == N) p[i] = N - 1; else if (max[p[i]-1] > max[p[i]+1]) p[i]--; else p[i]++; } for (i = 1; i <= N; i++) max[i] = 0; for (i = 1; i <= N; i++) chmax(&(max[p[i]]), i); for (i = 1, num = 0, len = 0; i <= N; i = j) { if (max[i] == 0) { j = i + 1; continue; } num++; for (j = i + 1; j <= N && max[j] != 0; j++); chmax(&len, j - i); } if (len == 2) break; } if (k <= 1000) printf("%d %d\n", k, num); fflush(stdout); return 0; }