#include using namespace std; using ll = long long; using P = pair; using T = tuple; #define al(a) a.begin(), a.end() #define ral(a) a.rbegin(), a.rend() #define sz(a) (int)a.size() #define rep(i, n) for (int i = 0; i < (n); ++i) #define rrep(i, n) for (int i = 1; i <= (n); ++i) #define drep(i, n) for (int i = (n)-1; i >= 0; --i) #define db(a, b) cout << #a << ": " << a << " " << #b << ": " << b << endl; int main() { string s; cin >> s; s.push_back('*'); ll ans = 0; ll tmp = 0, flag = 0; int n = sz(s); rep(i, n) { if (s[i] == '*') { if (flag) ans *= tmp; else ans += tmp; flag = 0; tmp = 0; } else if (s[i] == '+') { if (flag) ans *= tmp; else ans += tmp; flag = 1; tmp = 0; } else { tmp = tmp * 10 + (s[i] - '0'); } } cout << ans << endl; return 0; } // int main() { // string s; // cin >> s; // ll ans = 0; // ll tmp = 0, tmp2 = 0; // int n = sz(s); // rep(i, n) { // if (s[i] == '*') { // if (tmp2) { // ans += tmp * tmp2; // tmp2 = 0; // } // else // ans += tmp; // tmp = 0; // } // else if (s[i] == '+') { // if (tmp2) { tmp2 = tmp * tmp2; } // else // tmp2 = tmp; // tmp = 0; // } // else { // tmp = tmp * 10 + (s[i] - '0'); // } // } // if (tmp2) // ans += tmp * tmp2; // else if (tmp) // ans += tmp; // cout << ans << endl; // return 0; // }