結果
| 問題 |
No.49 算数の宿題
|
| コンテスト | |
| ユーザー |
mkan
|
| 提出日時 | 2018-07-03 21:39:11 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 1,564 bytes |
| コンパイル時間 | 846 ms |
| コンパイル使用メモリ | 93,724 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-12-23 01:59:25 |
| 合計ジャッジ時間 | 1,402 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
ソースコード
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
#include <stack>
#include <queue>
#include <set>
#include <bitset>
#include <map>
#include <tuple>
#include <unordered_map>
#include <list>
#include <numeric>
#include <utility>
#include <iterator>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <cstring>
#include <climits>
#include <ctime>
#include <cassert>
#define INF 1000000000
#define LINF 9000000000000000000
#define mod 1000000007
#define rep(i,n) for(int i=0;i<int(n);i++)
#define rrep(i,n) for(int i=n-1;i>=0;i--)
#define REP(i,a,b) for(int i=(a);i<int(b);i++)
#define all(x) (x).begin(),x.end()
#define pb push_back
#define mp make_pair
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef vector<int> vi;
typedef vector<long long>vll;
typedef pair<int,int> pi;
int dx[4]={1,0,-1,0};
int dy[4]={0,1,0,-1};
int ddx[8]={-1,-1,0,1,1,1,0,-1};
int ddy[8]={0,1,1,1,0,-1,-1,-1};
bool debug=false;
/*---------------------------------------------------*/
typedef string::const_iterator State;
int number(State &begin){
int ret=0;
while(isdigit(*begin)){
ret*=10;
ret+=(*begin)-'0';
begin++;
}
return ret;
}
int expression(State &begin){
int ret=number(begin);
while(1){
if(*begin=='+'){
begin++;
ret*=number(begin);
}else if(*begin=='*'){
begin++;
ret+=number(begin);
}else{
break;
}
}
return ret;
}
int main(){
string s;
cin>>s;
State begin=s.begin();
cout<<expression(begin)<<endl;
return 0;
}
mkan