結果

問題 No.539 インクリメント
ユーザー yuppe19 😺yuppe19 😺
提出日時 2020-03-25 21:48:51
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 21 ms / 2,000 ms
コード長 1,417 bytes
コンパイル時間 578 ms
コンパイル使用メモリ 58,832 KB
実行使用メモリ 4,380 KB
最終ジャッジ日時 2023-08-30 11:48:22
合計ジャッジ時間 1,571 ms
ジャッジサーバーID
(参考情報)
judge15 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
4,376 KB
testcase_01 AC 16 ms
4,380 KB
testcase_02 AC 20 ms
4,380 KB
testcase_03 AC 21 ms
4,380 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <cstdio>
#include <string>
using namespace std;

size_t readstring(char *s) {
  size_t ptr = 0;
  int c;
  for(;;) {
    c = getchar();
    switch(c) {
      case 10:
        break;
      default:
        goto str;
    }
  }
str:
  for(;;) {
    switch(c) {
      case 10:
        s[ptr] = '\0';
        return ptr;
      default:
        s[ptr++] = static_cast<char>(c);
    }
    c = getchar();
  }
}

string plus1(const string &s) {
  string t = "0" + s;
  int N = static_cast<int>(t.size());
  for(int i=N-1; i>=0; --i) {
    if(t[i] == '9') {
      t[i] = '0';
    } else {
      ++t[i];
      break;
    }
  }
  if(t[0] == '0') { t.erase(0, 1); }
  return t;
}

string doit(const string &s) {
  int n = static_cast<int>(s.size());
  // [lo, hi] をインクリメントする
  int lo = -1, hi = -1;
  for(int i=n-1; i>=0; --i) {
    if('0' <= s[i] && s[i] <= '9') {
      hi = i;
      break;
    }
  }
  if(hi == -1) { return s; }
  for(int i=hi; i>=0; --i) {
    if('0' <= s[i] && s[i] <= '9') {
      lo = i;
    } else {
      break;
    }
  }
  string r, t;
  for(int i=0; i<lo; ++i) { r += s[i]; }
  for(int i=lo; i<=hi; ++i) { t += s[i]; }
  r += plus1(t);
  for(int i=hi+1; i<n; ++i) { r += s[i]; }
  return r;
}

int main(void) {
  int T; scanf("%d", &T);
  char s[100005];
  for(int loop=0; loop<T; ++loop) {
    readstring(s);
    string t = doit(s);
    puts(t.c_str());
  }
  return 0;
}
0