結果
| 問題 |
No.1137 Circles
|
| ユーザー |
iiljj
|
| 提出日時 | 2020-10-09 00:10:23 |
| 言語 | C (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 9 ms / 2,000 ms |
| コード長 | 4,307 bytes |
| コンパイル時間 | 1,327 ms |
| コンパイル使用メモリ | 30,464 KB |
| 実行使用メモリ | 5,376 KB |
| 最終ジャッジ日時 | 2024-07-20 06:17:06 |
| 合計ジャッジ時間 | 1,581 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 22 |
コンパイルメッセージ
main.c: In function 'main':
main.c:6:15: warning: implicit declaration of function 'getc_unlocked' [-Wimplicit-function-declaration]
6 | tmp = getc_unlocked(stdin); \
| ^~~~~~~~~~~~~
main.c:48:5: note: in expansion of macro 'rd_int'
48 | rd_int(n, tmp);
| ^~~~~~
main.c:13:15: warning: implicit declaration of function 'getchar_unlocked' [-Wimplicit-function-declaration]
13 | tmp = getchar_unlocked(); \
| ^~~~~~~~~~~~~~~~
main.c:52:9: note: in expansion of macro 'rd_int_s'
52 | rd_int_s(X[i], tmp, sign);
| ^~~~~~~~
main.c:36:19: warning: implicit declaration of function 'putc_unlocked' [-Wimplicit-function-declaration]
36 | while (ptr--) putc_unlocked(buf[ptr] + '0', stdout);
| ^~~~~~~~~~~~~
main.c:71:5: note: in expansion of macro 'wt_int'
71 | wt_int(ma, buf, ptr);
| ^~~~~~
ソースコード
#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;
}
iiljj