結果
問題 |
No.1819 Mirrored 2
|
ユーザー |
|
提出日時 | 2022-01-24 02:15:43 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 4 ms / 2,000 ms |
コード長 | 748 bytes |
コンパイル時間 | 2,235 ms |
コンパイル使用メモリ | 197,148 KB |
最終ジャッジ日時 | 2025-01-27 15:05:27 |
ジャッジサーバーID (参考情報) |
judge1 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 26 |
ソースコード
#include <bits/stdc++.h> using namespace std; #define bokusunny ios::sync_with_stdio(false), cin.tie(nullptr); void solve() { int P, x; long long Q, y; cin >> P >> Q >> x >> y; auto rev = [](long long x) { string NS = to_string(x); reverse(NS.begin(), NS.end()); long long N = stoll(NS); return N; }; long long revN = y; while (revN % 10 == 0 || rev(revN) % P == 0) revN += Q; string NS = to_string(revN); reverse(NS.begin(), NS.end()); long long N = stoll(NS); N %= P; string ans = NS; for (int i = 0; i <= P; i++) { if (N == x) { cout << ans << endl; return; } N *= 10; N %= P; ans += '0'; } assert(false); } int main() { bokusunny; solve(); return 0; }