結果

問題 No.905 Sorted?
ユーザー kokatsu
提出日時 2021-11-28 15:36:01
言語 D
(dmd 2.109.1)
結果
AC  
実行時間 106 ms / 2,000 ms
コード長 668 bytes
コンパイル時間 1,866 ms
コンパイル使用メモリ 209,680 KB
実行使用メモリ 9,812 KB
最終ジャッジ日時 2024-06-22 13:32:07
合計ジャッジ時間 4,765 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 23
権限があれば一括ダウンロードができます

ソースコード

diff #

import std;

void main() {
    int N;
    readf("%d\n", N);

    auto A = readln.chomp.split.to!(long[]);

    auto inc = new int[](N), dec = new int[](N);
    foreach (i; 1 .. N) {
        inc[i] += inc[i-1], dec[i] += dec[i-1];

        if (A[i] >= A[i-1]) {
            ++inc[i];
        }

        if (A[i] <= A[i-1]) {
            ++dec[i];
        }
    }

    int Q;
    readf("%d\n", Q);

    foreach (i; 0 .. Q) {
        int l, r;
        readf("%d %d\n", l, r);

        int f, g;

        if (inc[r] - inc[l] == r - l) {
            f = 1;
        }

        if (dec[r] - dec[l] == r - l) {
            g = 1;
        }

        writeln(f, " ", g);
    }
}
0