結果
問題 | No.537 ユーザーID |
ユーザー |
![]() |
提出日時 | 2019-02-24 10:28:07 |
言語 | C++11 (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 15 ms / 2,000 ms |
コード長 | 1,327 bytes |
コンパイル時間 | 1,824 ms |
コンパイル使用メモリ | 168,788 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-12-18 00:53:40 |
合計ジャッジ時間 | 3,157 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 32 |
ソースコード
#include <bits/stdc++.h>using namespace std;typedef long long LL;int main() {// 1. 入力情報取得.LL N;cin >> N;// 2. ユーザーIDの末尾につける数 X は?// --- (ロジック誤り: ここから) --------------------------------------------// LL ans = 0;// LL upper = sqrt(N * 1.0);// for(int i = 1; i < upper + 1; i++) if(N % i == 0) ans++;// ans *= 2;// N が平方数(A * A == N)であれば, A が重複してカウントされているので, 1減算.// if(upper * upper == N) ans--;// --- (ロジック誤り: ここまで) --------------------------------------------// ex. 44 の 場合,// 44 = 1 * 44, 2 * 22, 4 * 11, 11 * 4, 22 * 2, 44 * 1 の 6組あるが,// X の 候補は, 144, 222, 114, 411, 441 の 5つになる点に注意!// -> small4.txt等 の WA に関する原因 と 推測.map<string, int> m;int upper = sqrt(N * 1.0);for(int i = 1; i < upper + 1; i++){if(N % i == 0){string s1 = to_string(i), s2 = to_string(N / i);string ab = s1 + s2, ba = s2 + s1;// cout << ab << " " << ba << endl;m[ab]++, m[ba]++;}}// 3. 終了.int ans = m.size();cout << ans << endl;return 0;}