結果

問題 No.25 有限小数
コンテスト
ユーザー purple_jwl
提出日時 2015-03-10 23:24:49
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
実行時間 -
コード長 846 bytes
コンパイル時間 1,806 ms
コンパイル使用メモリ 165,400 KB
実行使用メモリ 14,024 KB
最終ジャッジ日時 2024-06-24 17:08:24
合計ジャッジ時間 8,695 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 16 WA * 1 TLE * 1 -- * 13
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>

#define REP(i, x, n) for(int i = x; i < (int)(n); i++)
#define rep(i, n) REP(i, 0, n)
#define all(x) (x).begin(), (x).end()
#define rall(x) (x).rbegin(), (x).rend()
#define F first
#define S second
#define mp make_pair

using namespace std;

typedef long long ll;
typedef unsigned long long ull;
typedef pair<int, int> P;

int main() {
  // ios_base::sync_with_stdio(false);
  ll N, M;
  cin >> N >> M;

  if(N % M == 0) {
    ll ans = N / M;
    while(ans % 10 == 0) ans /= 10;
    cout << ans << endl;
  }
  else {
    set<pair<ll, int>> d;
    N %= M;
    int ans = 0;
    while(N % M) {
      while(N < M) N *= 10;
      int v = N / M;
      if(d.count(mp(N, v))) {
        ans = -1;
        break;
      }
      d.insert(mp(N, v));
      ans = v;
      N %= M;
    }
    cout << ans << endl;
  }
    
  return 0;
}
0