結果
問題 | No.1871 divisXor |
ユーザー | phspls |
提出日時 | 2023-01-12 02:47:13 |
言語 | Rust (1.77.0 + proconio) |
結果 |
AC
|
実行時間 | 47 ms / 2,000 ms |
コード長 | 1,229 bytes |
コンパイル時間 | 13,621 ms |
コンパイル使用メモリ | 392,300 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-06-02 03:35:30 |
合計ジャッジ時間 | 15,176 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
6,816 KB |
testcase_01 | AC | 1 ms
6,816 KB |
testcase_02 | AC | 36 ms
6,940 KB |
testcase_03 | AC | 11 ms
6,944 KB |
testcase_04 | AC | 8 ms
6,944 KB |
testcase_05 | AC | 19 ms
6,940 KB |
testcase_06 | AC | 19 ms
6,940 KB |
testcase_07 | AC | 25 ms
6,944 KB |
testcase_08 | AC | 44 ms
6,940 KB |
testcase_09 | AC | 35 ms
6,940 KB |
testcase_10 | AC | 18 ms
6,944 KB |
testcase_11 | AC | 34 ms
6,944 KB |
testcase_12 | AC | 10 ms
6,940 KB |
testcase_13 | AC | 4 ms
6,944 KB |
testcase_14 | AC | 38 ms
6,940 KB |
testcase_15 | AC | 14 ms
6,944 KB |
testcase_16 | AC | 19 ms
6,944 KB |
testcase_17 | AC | 47 ms
6,940 KB |
testcase_18 | AC | 18 ms
6,944 KB |
testcase_19 | AC | 14 ms
6,940 KB |
testcase_20 | AC | 43 ms
6,944 KB |
testcase_21 | AC | 31 ms
6,944 KB |
testcase_22 | AC | 1 ms
6,940 KB |
testcase_23 | AC | 1 ms
6,944 KB |
testcase_24 | AC | 1 ms
6,940 KB |
testcase_25 | AC | 1 ms
6,940 KB |
testcase_26 | AC | 26 ms
6,948 KB |
testcase_27 | AC | 26 ms
6,944 KB |
testcase_28 | AC | 25 ms
6,940 KB |
testcase_29 | AC | 11 ms
6,940 KB |
testcase_30 | AC | 35 ms
6,940 KB |
コンパイルメッセージ
warning: unused import: `std::collections::HashMap` --> src/main.rs:1:5 | 1 | use std::collections::HashMap; | ^^^^^^^^^^^^^^^^^^^^^^^^^ | = note: `#[warn(unused_imports)]` on by default
ソースコード
use std::collections::HashMap; fn calc(val: usize) -> usize { let mut ret = 0usize; for i in 1..=(val as f64).sqrt() as usize { if val % i == 0 { ret += i; if i != val / i { ret += val / i; } } } ret } fn main() { let mut n = String::new(); std::io::stdin().read_line(&mut n).ok(); let n: usize = n.trim().parse().unwrap(); if n == 0 { println!("-1"); return; } let nstr = format!("{:b}", n).chars().collect::<Vec<_>>(); let mut length = nstr.len(); let mut result = vec![]; let mut base = 1usize << (length-1); let mut current = 0usize; loop { while format!("{:b}", calc(base)).len() != length { base += 1; } current ^= calc(base); result.push(base); if current == n { break; } let current_str = format!("{:b}", current).chars().collect::<Vec<_>>(); length = nstr.len() - (0..nstr.len()).filter(|&i| nstr[i] != current_str[i]).nth(0).unwrap(); base = 1usize << (length - 1); } println!("{}", result.len()); println!("{}", result.iter().map(|v| v.to_string()).collect::<Vec<_>>().join(" ")); }