結果
問題 |
No.708 (+ー)の式
|
ユーザー |
![]() |
提出日時 | 2019-05-02 10:02:23 |
言語 | C (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 2,000 ms |
コード長 | 696 bytes |
コンパイル時間 | 1,043 ms |
コンパイル使用メモリ | 29,312 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-12-31 13:12:33 |
合計ジャッジ時間 | 1,471 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 12 |
ソースコード
// yukicoder: No.708 (+ー)の式 // 2019.5.2 bal4u #include <stdio.h> #include <ctype.h> #if 1 #define pc(c) putchar_unlocked(c) #else #define pc(c) putchar(c) #endif char S[105], *p; int expr(); int num() { int n = 0; while (isdigit(*p)) n = 10*n + (*p++ & 0xf); return n; } int factor() { int x; if (*p == '-') p++, x = -factor(); else if (*p == '(') p++, x = expr(), p++; else x = num(); return x; } int expr() { int x, y, op; x = factor(); while (1) { if (*p == '+') op = 1; else if (*p == '-') op = 0; else break; p++; y = factor(); if (op) x += y; else x -= y; } return x; } int main() { scanf("%s", p = S); printf("%d\n", expr()); return 0; }