結果

問題 No.539 インクリメント
ユーザー y_taira_cy_taira_c
提出日時 2017-08-05 10:20:44
言語 C++14
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 6 ms / 2,000 ms
コード長 2,317 bytes
コンパイル時間 1,673 ms
コンパイル使用メモリ 169,940 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-11 20:31:01
合計ジャッジ時間 2,630 ms
ジャッジサーバーID
(参考情報)
judge5 / judge1
このコードへのチャレンジ
(要ログイン)

テストケース

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

ソースコード

diff #

#include <bits/stdc++.h>

using namespace std;


typedef int32_t h_int32;
typedef int64_t h_int64;
typedef uint32_t uh_int32;
typedef uint64_t uh_int64;
typedef h_int64 h_int;

#define REP( i, n ) for(h_int i = 0; i < ( h_int )( n ); ++i )
#define REPR( i, n ) for(h_int i = ( h_int )( n ); i >= 0; --i )
#define FOR( i, a, n ) for(h_int i = ( h_int )( a ); i < ( h_int )( n ); ++i )
#define FORR( i, a, n ) for(h_int i = ( h_int )( n ); i >= ( h_int )( a ); --i)

#define ALL( x ) x.begin(), x.end()

#define DOUT( x ) cerr << #x << " = " << x << "\n"
#define COUT( x ) cout << ( x ) << "\n"
#define DOUBLECOUT( num, x ) cout << fixed << setprecision( num ) << ( x ) << "\n"

#define INF 999999999
#define PI 3.14159265359

#ifdef _DEBUG
h_int res = 12679;
#endif


bool IsNumber( char c )
{
        return c >= '0' && c <= '9';
}
void f( string s )
{
        pair<int, int> p = { -1, -1 };
        REPR( i, s.size() - 1 )
        {
                if(IsNumber( s[i] ) )
                {
                        p.second = i;
                        break;
                }
        }
        REPR( i, p.second - 1 )
        {
                if(!IsNumber( s[i] ) )
                {
                        p.first = i + 1;
                        break;
                }
                else if( i == 0)
                {
                        p.first = i;
                }
        }
        if( p.first == -1)
        {
                COUT( s );
                return;
        }
        string a = s.substr( 0, p.first );
        string b = s.substr( p.first, p.second - p.first + 1 );
        string c = s.substr( p.second + 1 );

        REPR( j, b.size() - 1 )
        {
                if(b[j] == '9')
                {
                        b[j] = '0';
                        if( j == 0)
                        {
                                b = "1" + b;
                        }
                        continue;
                }
                b[j]++;
                break;
        }
        cout << a << b << c << "\n";
}


signed main()
{
        ios::sync_with_stdio( false );
        cin.tie( 0 );

        int n; cin >> n;
        string s;
        cin.ignore();
        REP( i, n )
        {
                getline( cin, s );
                f( s );
        }

        return 0;
}
0