結果
| 問題 | 
                            No.49 算数の宿題
                             | 
                    
| コンテスト | |
| ユーザー | 
                             めうめう🎒
                         | 
                    
| 提出日時 | 2016-03-30 21:01:01 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 2 ms / 5,000 ms | 
| コード長 | 1,067 bytes | 
| コンパイル時間 | 768 ms | 
| コンパイル使用メモリ | 74,616 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-12-23 01:50:17 | 
| 合計ジャッジ時間 | 1,288 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge2 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 10 | 
ソースコード
#include <algorithm>
#include <cstdio>
#include <iostream>
#include <map>
#include <math.h>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <string>
#include <vector>
using namespace std;
#define ll long long
#define INF (1 << 30)
#define INFLL (1LL << 60)
// ll stoi(string str){
// 	int num = 0;
// 	for(int i = 0;i < str.size();i++){
// 		num *= 10;
// 		num += str[i] - '0';
// 	}
// 	return num;
// }
int main() {
	string str,str2 = "";
	ll ans = 0;
	cin >> str;
	bool flag = true;
	int kigo = 0;
	for(int i = 0;i < str.size();i++){
		if('0' <= str[i] && str[i] <= '9'){
			str2 += str[i];
		}else if(flag){
			ans = stoi(str2);
			str2 = "";
			flag = false;
			if(str[i] == '*'){
				kigo = 1;
			}else{
				kigo = 2;
			}
		}else{
			if(kigo == 1){
				ans += stoi(str2);
			}else if(kigo == 2){
				ans *= stoi(str2);
			}
			str2 = "";
			if(str[i] == '*'){
				kigo = 1;
			}else{
				kigo = 2;
			}
		}
	}
	if(kigo == 1){
		ans += stoi(str2);
	}else if(kigo == 2){
		ans *= stoi(str2);
	}
	cout << ans << endl;
	return 0;
}
            
            
            
        
            
めうめう🎒