結果
| 問題 | No.3 ビットすごろく |
| コンテスト | |
| ユーザー |
ixTL255
|
| 提出日時 | 2023-01-04 12:15:21 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 5,000 ms |
| コード長 | 576 bytes |
| コンパイル時間 | 14,039 ms |
| コンパイル使用メモリ | 379,748 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-11-27 14:39:10 |
| 合計ジャッジ時間 | 15,467 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 33 |
ソースコード
use std::collections::VecDeque;
fn main() {
let mut n = String::new();
std::io::stdin().read_line(&mut n).ok();
let n: usize = n.trim().parse().unwrap();
let mut v: Vec<i32> = vec![-1; n + 1];
let mut q: VecDeque<usize> = VecDeque::new();
v[1] = 1;
q.push_back(1);
while !q.is_empty() {
let p = q.pop_front().unwrap();
let bp = p.count_ones() as usize;
if p - bp > 0 && v[p - bp] == -1 {
v[p - bp] = v[p] + 1;
q.push_back(p - bp);
}
if p + bp <= n && v[p + bp] == -1 {
v[p + bp] = v[p] + 1;
q.push_back(p + bp);
}
}
println!("{}", v[n]);
}
ixTL255