結果
| 問題 |
No.25 有限小数
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2014-11-15 11:05:33 |
| 言語 | Java (openjdk 23) |
| 結果 |
AC
|
| 実行時間 | 142 ms / 5,000 ms |
| コード長 | 943 bytes |
| コンパイル時間 | 3,684 ms |
| コンパイル使用メモリ | 74,892 KB |
| 実行使用メモリ | 55,932 KB |
| 最終ジャッジ日時 | 2024-11-15 21:07:03 |
| 合計ジャッジ時間 | 8,808 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 31 |
ソースコード
import java.util.Scanner;
/**
* yukicoder no.25
* @author scache
*
*/
public class FiniteDecimal {
public static void main(String[] args) {
FiniteDecimal p = new FiniteDecimal();
}
public FiniteDecimal() {
Scanner sc = new Scanner(System.in);
long n = sc.nextLong();
long m = sc.nextLong();
System.out.println(solve(n, m));
}
public int solve(long n, long m) {
long g = gcd(n, m);
m /= g;
n /= g;
while(n%10 == 0)
n /= 10;
// System.out.println(n +" " + n +" "+m);
long res = n % 10;
while(m%10==0)
m /= 10;
while(m%2==0){
res *= 5;
res %= 1000000000000000000L;
m /= 2;
}
while(m%5==0){
res *= 2;
res %= 1000000000000000000L;
m /= 5;
}
if(m==1)
return (int)(res%10);
else
return -1;
}
private long gcd(long a, long b){
if(b==0)
return a;
else
return gcd(b, a%b);
}
}