結果

問題 No.1137 Circles
ユーザー iiljjiiljj
提出日時 2020-10-09 00:10:23
言語 C
(gcc 12.3.0)
結果
AC  
実行時間 7 ms / 2,000 ms
コード長 4,307 bytes
コンパイル時間 777 ms
コンパイル使用メモリ 29,360 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-27 12:09:21
合計ジャッジ時間 2,620 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,376 KB
testcase_01 AC 7 ms
4,376 KB
testcase_02 AC 2 ms
4,380 KB
testcase_03 AC 4 ms
4,380 KB
testcase_04 AC 5 ms
4,376 KB
testcase_05 AC 2 ms
4,380 KB
testcase_06 AC 6 ms
4,380 KB
testcase_07 AC 3 ms
4,376 KB
testcase_08 AC 6 ms
4,376 KB
testcase_09 AC 3 ms
4,376 KB
testcase_10 AC 4 ms
4,376 KB
testcase_11 AC 4 ms
4,380 KB
testcase_12 AC 7 ms
4,380 KB
testcase_13 AC 4 ms
4,380 KB
testcase_14 AC 7 ms
4,376 KB
testcase_15 AC 4 ms
4,380 KB
testcase_16 AC 4 ms
4,376 KB
testcase_17 AC 2 ms
4,376 KB
testcase_18 AC 7 ms
4,380 KB
testcase_19 AC 3 ms
4,380 KB
testcase_20 AC 3 ms
4,376 KB
testcase_21 AC 0 ms
4,376 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.c: 関数 ‘main’ 内:
main.c:6:15: 警告: 関数 ‘getc_unlocked’ の暗黙的な宣言です [-Wimplicit-function-declaration]
    6 |         tmp = getc_unlocked(stdin);                                                                                    \
      |               ^~~~~~~~~~~~~
main.c:48:5: 備考: in expansion of macro ‘rd_int’
   48 |     rd_int(n, tmp);
      |     ^~~~~~
main.c:13:15: 警告: 関数 ‘getchar_unlocked’ の暗黙的な宣言です [-Wimplicit-function-declaration]
   13 |         tmp = getchar_unlocked();                                                                                      \
      |               ^~~~~~~~~~~~~~~~
main.c:52:9: 備考: in expansion of macro ‘rd_int_s’
   52 |         rd_int_s(X[i], tmp, sign);
      |         ^~~~~~~~
main.c:36:19: 警告: 関数 ‘putc_unlocked’ の暗黙的な宣言です [-Wimplicit-function-declaration]
   36 |     while (ptr--) putc_unlocked(buf[ptr] + '0', stdout);
      |                   ^~~~~~~~~~~~~
main.c:71:5: 備考: in expansion of macro ‘wt_int’
   71 |     wt_int(ma, buf, ptr);
      |     ^~~~~~

ソースコード

diff #

#include <stdio.h>

// int tmp, var = 0; を先に宣言する
#define rd_int(var, tmp)                                                                                               \
    for (;;) {                                                                                                         \
        tmp = getc_unlocked(stdin);                                                                                    \
        if (tmp < '0' || tmp > '9') break;                                                                             \
        var = var * 10 + tmp - '0';                                                                                    \
    }
// int tmp, var = 0, sign = 0; を先に宣言する
#define rd_int_s(var, tmp, sign)                                                                                       \
    for (;;) {                                                                                                         \
        tmp = getchar_unlocked();                                                                                      \
        if (tmp == '-') {                                                                                              \
            sign = 1;                                                                                                  \
            break;                                                                                                     \
        } else if ('0' <= tmp && tmp <= '9') {                                                                         \
            var = tmp - '0';                                                                                           \
            break;                                                                                                     \
        }                                                                                                              \
    }                                                                                                                  \
    for (;;) {                                                                                                         \
        tmp = getc_unlocked(stdin);                                                                                    \
        if (tmp < '0' || tmp > '9') break;                                                                             \
        var = var * 10 + tmp - '0';                                                                                    \
    }                                                                                                                  \
    if (sign) var = -var;

// char buf[9]; int ptr = 0; を先に宣言する
#define wt_int(var, buf, ptr)                                                                                          \
    while (var) {                                                                                                      \
        buf[ptr++] = var % 10;                                                                                         \
        var /= 10;                                                                                                     \
    }                                                                                                                  \
    if (!ptr) buf[ptr++] = 0;                                                                                          \
    while (ptr--) putc_unlocked(buf[ptr] + '0', stdout);

#define LEN 400000
#define OFFSET 200000
#define MN 100000
int imos[LEN];
int X[MN], R[MN];

int main() {
    int n = 0, i, tmp, sign, ptr = 0, xmi = OFFSET, xma = -OFFSET;
    char buf[6];

    rd_int(n, tmp);

    for (i = 0; i < n; ++i) {
        sign = 0;
        rd_int_s(X[i], tmp, sign);
        rd_int(R[i], tmp);
        if (X[i] - R[i] < xmi) xmi = X[i] - R[i];
        if (X[i] + R[i] > xma) xma = X[i] + R[i];
    }
    int len = xma - xmi + 1;
    // printf(" -> %d %d %d\n", xma, xmi, len);
    for (i = 0; i < n; ++i) {
        X[i] -= xmi;
        ++imos[X[i] - R[i]];
        --imos[X[i] + R[i]];
    }

    int ma = 0, acc = 0;
    for (i = 0; i < len; ++i) {
        acc += imos[i];
        if (acc > ma) ma = acc;
    }

    wt_int(ma, buf, ptr);
    return 0;
}
0