結果
| 問題 | No.1135 RPN |
| ユーザー |
iiljj
|
| 提出日時 | 2020-10-06 22:10:40 |
| 言語 | C(gnu17) (gcc 15.2.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,146 bytes |
| 記録 | |
| コンパイル時間 | 190 ms |
| コンパイル使用メモリ | 40,008 KB |
| 最終ジャッジ日時 | 2026-02-22 06:09:21 |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 WA * 1 |
| other | AC * 1 WA * 15 |
ソースコード
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main() {
int n = 0, m, k, pt = 0, stk[500];
for (;;) {
k = getc_unlocked(stdin);
if (k < '0' || k > '9') break;
n = n * 10 + k - '0';
}
// printf("%d\n", n);
for (int i = 0; i < n; ++i) {
// printf("i=%d, n=%d\n", i, n);
k = getc_unlocked(stdin);
if (k == '+') {
--pt;
stk[pt - 1] += stk[pt];
getc_unlocked(stdin);
} else if (k == '-') {
--pt;
stk[pt - 1] -= stk[pt];
getc_unlocked(stdin);
} else {
int m = k - 48;
for (;;) {
k = getc_unlocked(stdin);
if (k < '0' || k > '9') break;
m = n * 10 + k - '0';
}
stk[pt++] = m;
}
}
n = 0, m = 0, k = *stk;
char f[6];
if (k < 0) {
m = 1;
k = -k;
}
while (k) {
f[n++] = k % 10;
k /= 10;
}
if (!n) f[n++] = 0;
if (m) putc_unlocked('-', stdout);
while (n--) putc_unlocked(f[n] + '0', stdout);
return 0;
}
iiljj