結果

問題 No.49 算数の宿題
ユーザー leaf+leaf+
提出日時 2019-04-16 12:33:00
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 5,000 ms
コード長 878 bytes
コンパイル時間 1,505 ms
コンパイル使用メモリ 53,180 KB
実行使用メモリ 4,384 KB
最終ジャッジ日時 2023-08-24 17:42:35
合計ジャッジ時間 1,271 ms
ジャッジサーバーID
(参考情報)
judge12 / judge13
このコードへのチャレンジ(β)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,376 KB
testcase_01 AC 2 ms
4,376 KB
testcase_02 AC 1 ms
4,376 KB
testcase_03 AC 1 ms
4,384 KB
testcase_04 AC 2 ms
4,376 KB
testcase_05 AC 1 ms
4,376 KB
testcase_06 AC 2 ms
4,380 KB
testcase_07 AC 2 ms
4,376 KB
testcase_08 AC 2 ms
4,376 KB
testcase_09 AC 2 ms
4,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <string>
using namespace std;
int main() {
    string s, q = "";
    int i, n = -1, dx = 0;
    cin >> s;
    for (i = 0; i < s.length(); i++) {
    	if (n == -1) {
        	if (s[i] == '*') {n = atoi(q.c_str()); dx = 1; q = "";}
        	else if (s[i] == '+') {n = atoi(q.c_str()); dx = 2; q = "";}
        	else {q += s[i];}
    	}
    	else {
        	if (s[i] == '*') {
        		if (dx == 1) {n += atoi(q.c_str()); q = "";}
    			if (dx == 2) {n *= atoi(q.c_str()); q = "";}
    			dx = 1;
        	}
        	else if (s[i] == '+') {
        		if (dx == 1) {n += atoi(q.c_str()); q = "";}
    			if (dx == 2) {n *= atoi(q.c_str()); q = "";}
    			dx = 2;
        	}
        	else {q += s[i];}
    	}
    }
    if (dx == 1) {n += atoi(q.c_str()); q = "";}
    if (dx == 2) {n *= atoi(q.c_str()); q = "";}
    cout << n << endl;
    return 0;
}
0