結果
問題 |
No.1339 循環小数
|
ユーザー |
|
提出日時 | 2021-01-15 22:39:15 |
言語 | Rust (1.83.0 + proconio) |
結果 |
TLE
|
実行時間 | - |
コード長 | 934 bytes |
コンパイル時間 | 13,602 ms |
コンパイル使用メモリ | 392,304 KB |
実行使用メモリ | 13,772 KB |
最終ジャッジ日時 | 2024-11-26 16:37:05 |
合計ジャッジ時間 | 62,963 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 20 TLE * 16 |
ソースコード
use std::io::*; fn f(x: usize, n: usize) -> usize { x * 10 % n } fn cycle(n: usize) -> usize { let mut power = 1; let mut len = 1; let mut slow = 10; let mut fast = f(10, n); while slow != fast { if power == len { slow = fast; power *= 2; len = 0; } fast = f(fast, n); len += 1; } len } fn main() { let mut s: String = String::new(); std::io::stdin().read_to_string(&mut s).ok(); let mut itr = s.trim().split_whitespace(); let t: usize = itr.next().unwrap().parse().unwrap(); for _ in 0..t { let n: usize = itr.next().unwrap().parse().unwrap(); let mut m = n; while m % 2 == 0 { m /= 2; } while m % 5 == 0 { m /= 5; } if m == 1 { println!("1"); continue; } println!("{}", cycle(n)); } }