結果
問題 |
No.1339 循環小数
|
ユーザー |
|
提出日時 | 2021-01-15 22:30:09 |
言語 | Rust (1.83.0 + proconio) |
結果 |
TLE
|
実行時間 | - |
コード長 | 966 bytes |
コンパイル時間 | 19,566 ms |
コンパイル使用メモリ | 376,696 KB |
実行使用メモリ | 12,072 KB |
最終ジャッジ日時 | 2024-11-26 16:22:01 |
合計ジャッジ時間 | 64,732 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
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 osoi = 10; let mut hayai = f(10, n); while osoi != hayai { osoi = f(osoi, n); hayai = f(f(hayai, n), n); } let mut len = 1; hayai = f(hayai, n); while osoi != hayai { len += 1; hayai = f(hayai, n); } 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(); // 10^x mod nの最小循環 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)); } }