結果

問題 No.193 筒の数式
ユーザー koba-e964koba-e964
提出日時 2015-05-21 19:58:09
言語 C++11
(gcc 11.4.0)
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 1,872 bytes
コンパイル時間 744 ms
コンパイル使用メモリ 90,212 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-09-20 08:40:19
合計ジャッジ時間 1,784 ms
ジャッジサーバーID
(参考情報)
judge12 / judge14
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

#include <algorithm>
#include <bitset>
#include <cassert>
#include <cctype>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <deque>
#include <functional>
#include <iomanip>
#include <iostream>
#include <list>
#include <map>
#include <numeric>
#include <queue>
#include <set>
#include <sstream>
#include <stack>
#include <string>
#include <utility>
#include <vector>

#define REP(i,s,n) for(int i=(int)(s);i<(int)(n);i++)

using namespace std;
typedef long long int ll;
typedef vector<int> VI;
typedef pair<int, int> PI;
const double EPS=1e-9;

const ll err = 1LL << 60;

typedef pair<int, ll> result;

result p_int(string s, int v) {
  if (v >= s.length()) {
    return result(0, err);
  }
  ll q = 0;
  int len = 0;
  for (; v + len < s.length(); ++len) {
    char c = s[v + len];
    if (('0' <= c && c <= '9') == false) {
      break;
    }
    q *= 10;
    q += c - '0';
  }
  if (len >= 1) {
    return result(len, q);
  }
  return result(0, err);
}


result p_expr(const string &s, int v) {
  ll res;
  int pos = v;
  result r1 = p_int(s, v);
  if (r1.first == 0) {
    return result(0, err);
  }
  pos += r1.first;
  res = r1.second;
  while (pos < s.length()) {
    char op = s[pos];
    switch (op) {
    case '+':
    case '-':
      break;
    default:
      return result(pos - v, res);
    }
    result sub = p_int(s, pos + 1);
    if (sub.first == 0) {
      return result(pos - v, res);
    }
    res = op == '+' ? res + sub.second : res - sub.second;
    pos += sub.first + 1;
  }
  return result(s.length() - v, res);
}



int main(void){
  string s;
  cin >> s;
  int n = s.length();
  ll m = -234567892345LL;
  REP(i, 0, n) {
    string t = s.substr(i, n) + s.substr(0, i);
    result r = p_expr(t, 0);
    if (r.first != n) {
      continue;
    }
    m = max(m, r.second);
  }
  cout << m << endl;
}
0