結果
問題 |
No.25 有限小数
|
ユーザー |
![]() |
提出日時 | 2015-02-22 23:09:23 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 1 ms / 5,000 ms |
コード長 | 520 bytes |
コンパイル時間 | 186 ms |
コンパイル使用メモリ | 23,552 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-15 21:10:46 |
合計ジャッジ時間 | 1,095 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 31 |
コンパイルメッセージ
main.cpp: In function ‘int main()’: main.cpp:13:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 13 | scanf( "%lld%lld", &N, &M ); | ~~~~~^~~~~~~~~~~~~~~~~~~~~~
ソースコード
// yukicoder 25 (http://yukicoder.me/problems/70) #include<cstdio> typedef long long ll; ll N, M; ll gcd( ll a, ll b ) { return b?gcd(b,a%b):a; } int main() { scanf( "%lld%lld", &N, &M ); ll g = gcd( N, M ); N /= g; M /= g; ll p2 = 0, p5 = 0; while( M % 2 == 0 ) ++p2, M>>=1; while( M % 5 == 0 ) ++p5, M/=5; if( M != 1 ) { puts("-1"); return 0; } while( N % 10 == 0 ) N /= 10; while( p2 < p5 ) ++p2, N=(N<<1)%10; while( p2 > p5 ) ++p5, N=(N*5)%10; printf( "%lld\n", N%10 ); return 0; }