結果

問題 No.193 筒の数式
コンテスト
ユーザー te-sh
提出日時 2017-04-20 17:04:44
言語 D
(dmd 2.112.0)
コンパイル:
dmd -fPIE -m64 -w -wi -O -release -inline -I/opt/dmd/src/druntime/import/ -I/opt/dmd/src/phobos -L-L/opt/dmd/linux/lib64/ -fPIC _filename_
実行:
./Main
結果
AC  
実行時間 2 ms / 1,000 ms
コード長 493 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 7,912 ms
コンパイル使用メモリ 263,780 KB
実行使用メモリ 7,716 KB
最終ジャッジ日時 2026-03-05 14:22:05
合計ジャッジ時間 8,729 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 16
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import std.algorithm, std.conv, std.range, std.stdio, std.string;
import std.regex;     // RegEx

void main()
{
  auto s = readln.chomp;
  
  auto l = s.length, ma = int.min;
  foreach (i; 0..l)
    ma = max(ma, calc(s[i..$] ~ s[0..i]));

  writeln(ma);
}

auto calc(string s)
{
  if (s[0] == '+' || s[0] == '-' || s[$-1] == '+' || s[$-1] == '-') return int.min;

  auto mi = s.matchAll(r"[-+]?\d+"), acc = 0;
  foreach (m; mi) {
    acc += m[0].to!int;
    m.popFront();
  }

  return acc;
}
0