結果
| 問題 | No.539 インクリメント | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 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);
      |          ~~~~~^~~~~~~~~~
            
            ソースコード
#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;
}
            
            
            
        