結果

問題 No.539 インクリメント
ユーザー yuppe19 😺
提出日時 2020-03-25 21:48:51
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 26 ms / 2,000 ms
コード長 1,417 bytes
コンパイル時間 822 ms
コンパイル使用メモリ 58,720 KB
最終ジャッジ日時 2025-01-09 10:09:33
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 3
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:72:15: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   72 |   int T; scanf("%d", &T);
      |          ~~~~~^~~~~~~~~~

ソースコード

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