結果

問題 No.420 mod2漸化式
ユーザー phsplsphspls
提出日時 2020-07-05 12:47:03
言語 Rust
(1.83.0 + proconio)
結果
MLE  
実行時間 -
コード長 1,048 bytes
コンパイル時間 19,035 ms
コンパイル使用メモリ 390,932 KB
実行使用メモリ 813,148 KB
最終ジャッジ日時 2024-09-22 08:47:34
合計ジャッジ時間 17,557 ms
ジャッジサーバーID
(参考情報)
judge4 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other MLE * 1 -- * 34
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

fn combinations(n: usize, r: usize) -> Vec<Vec<usize>> {
let mut result: Vec<Vec<usize>> = vec![vec![]];
if n == 0 || r == 0 { return result; }
for j in 0..n {
let limit = result.len();
for i in 0..limit {
if result[i].len() < r && n - j >= r - result[i].len() {
let mut selected = result[i].clone();
selected.push(j);
result.push(selected);
}
}
}
result.iter().filter(|&val| val.len() == r).map(|i| i.clone()).collect()
}
//TODO
fn main() {
let mut x = String::new();
std::io::stdin().read_line(&mut x).ok();
let x: usize = x.trim().parse().unwrap();
if x > 31 {
println!("0 0");
return;
}
let ranks: Vec<usize> = (0..31).map(|i| 2usize.pow(i as u32)).collect();
let combs = combinations(31, x);
let count = combs.len();
let result: usize = combs.iter()
.map(|vals| vals.iter().map(|&i| ranks[i]).sum::<usize>())
.sum();
println!("{} {}", count, result);
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0