当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Rust VecDeque.binary_search用法及代码示例


本文简要介绍rust语言中 alloc::collections::vec_deque::VecDeque.binary_search 的用法。

用法

二进制在这个排序的VecDeque 中搜索给定的元素。

如果找到该值,则返回 Result::Ok ,其中包含匹配元素的索引。如果有多个匹配项,则可以返回任何一个匹配项。如果未找到该值,则返回 Result::Err ,其中包含可以插入匹配元素的索引,同时保持排序顺序。

另请参见 binary_search_by binary_search_by_key partition_point

例子

查找一系列四个元素。第一个被发现,具有唯一确定的位置;没有找到第二个和第三个;第四个可以匹配 [1, 4] 中的任何位置。

use std::collections::VecDeque;

let deque: VecDeque<_> = vec![0, 1, 1, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55].into();

assert_eq!(deque.binary_search(&13),  Ok(9));
assert_eq!(deque.binary_search(&4),   Err(7));
assert_eq!(deque.binary_search(&100), Err(13));
let r = deque.binary_search(&1);
assert!(matches!(r, Ok(1..=4)));

如果要将项目插入已排序的 VecDeque ,同时保持排序顺序:

use std::collections::VecDeque;

let mut deque: VecDeque<_> = vec![0, 1, 1, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55].into();
let num = 42;
let idx = deque.binary_search(&num).unwrap_or_else(|x| x);
deque.insert(idx, num);
assert_eq!(deque, &[0, 1, 1, 1, 1, 2, 3, 5, 8, 13, 21, 34, 42, 55]);

相关用法


注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 alloc::collections::vec_deque::VecDeque.binary_search。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。