結果

問題 No.2607 Add One Digit
ユーザー pvviet002pvviet002
提出日時 2024-04-19 16:47:12
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
WA  
実行時間 -
コード長 869 bytes
コンパイル時間 968 ms
コンパイル使用メモリ 81,400 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-11 08:51:12
合計ジャッジ時間 2,135 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <string>
#include <unordered_set>

using namespace std;

int main() {
    int N;
    cin >> N;
    string S = to_string(N);
    unordered_set<string> uniqueNumbers;

    // Thử thêm mỗi chữ số từ 1 đến 9 vào mọi vị trí có thể
    for (char d = '1'; d <= '9'; ++d) {
        // Chèn vào đầu chuỗi
        string newNumber = d + S;
        uniqueNumbers.insert(newNumber);

        // Chèn vào cuối chuỗi
        newNumber = S + d;
        uniqueNumbers.insert(newNumber);

        // Chèn vào giữa chuỗi
        for (int i = 0; i < S.length(); ++i) {
            newNumber = S.substr(0, i + 1) + d + S.substr(i + 1);
            uniqueNumbers.insert(newNumber);
        }
    }

    // In ra số lượng số duy nhất có thể tạo ra
    cout << uniqueNumbers.size() << endl;
    return 0;
}
0