結果
| 問題 |
No.1458 Segment Function
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-06-17 14:43:12 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 53 ms / 2,000 ms |
| コード長 | 761 bytes |
| コンパイル時間 | 910 ms |
| コンパイル使用メモリ | 89,980 KB |
| 最終ジャッジ日時 | 2025-02-14 22:19:29 |
|
ジャッジサーバーID (参考情報) |
judge7 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 32 |
ソースコード
#include<iostream>
#include<string>
#include<vector>
#include<unordered_map>
int main() {
std::string P, N;
std::cin >> P >> N;
const std::vector<int> dig{6, 2, 5, 5, 4, 5, 6, 4, 7, 6};
std::unordered_map<char, int> dig_str;
for (int i = 0; i < dig.size(); i++) {
const char c = (char) (i + '0');
dig_str[c] = dig.at(i);
}
dig_str['-'] = 1;
int MAX;
if (N.size() >= 7) {
MAX = 1e6;
} else {
MAX = std::stoi(N);
}
for (int i = 0; i < MAX; i++) {
int new_P_int = 0;
for (const auto p: P) new_P_int += dig_str.at(p);
std::string new_P = std::to_string(new_P_int);
if (P == new_P) break;
P = new_P;
}
std::cout << P << std::endl;
}