結果
| 問題 | No.25 有限小数 |
| コンテスト | |
| ユーザー |
LayCurse
|
| 提出日時 | 2014-11-07 10:37:30 |
| 言語 | C++11 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 5,000 ms |
| コード長 | 630 bytes |
| 記録 | |
| コンパイル時間 | 1,707 ms |
| コンパイル使用メモリ | 174,376 KB |
| 実行使用メモリ | 6,400 KB |
| 最終ジャッジ日時 | 2026-05-10 21:22:29 |
| 合計ジャッジ時間 | 3,360 ms |
|
ジャッジサーバーID (参考情報) |
judge3_0 / judge1_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 31 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
#define REP(i,a,b) for(i=a;i<b;i++)
#define rep(i,n) REP(i,0,n)
#define ll long long
#define ull unsigned ll
template<class T> T GCD(T a,T b){T r; while(a){r=b; b=a; a=r%a;} return b;}
int main(){
int i, j, k;
int p2 = 0, p5 = 0;
ull N, M, g;
scanf("%llu%llu",&N,&M);
g = GCD(N,M);
N /= g; M /= g;
while(M%2==0) M/=2, p2++;
while(M%5==0) M/=5, p5++;
if(M>1){ puts("-1"); return 0; }
while(N%10==0) N /= 10;
N %= 10;
while(p2>p5) p5++, N=(N*5)%10;
while(p2<p5) p2++, N=(N*2)%10;
printf("%d\n",(int)N);
return 0;
}
LayCurse