當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Rust VecDeque.binary_search_by_key用法及代碼示例


本文簡要介紹rust語言中 std::collections::VecDeque.binary_search_by_key 的用法。

用法

pub fn binary_search_by_key<'a, B, F>(    &'a self,     b: &B,     f: F) -> Result<usize, usize> where    F: FnMut(&'a T) -> B,    B: Ord,

二進製搜索這個排序的VecDeque 使用 key 提取函數。

假設 VecDeque 是按鍵排序的,例如 make_contiguous().sort_by_key() 使用相同的鍵提取函數。

如果找到該值,則返回 Result::Ok ,其中包含匹配元素的索引。如果有多個匹配項,則可以返回任何一個匹配項。如果未找到該值,則返回 Result::Err ,其中包含可以插入匹配元素的索引,同時保持排序順序。

另請參見 binary_search binary_search_by partition_point

例子

在按第二個元素排序的對切片中查找一係列四個元素。第一個被發現,具有唯一確定的位置;沒有找到第二個和第三個;第四個可以匹配 [1, 4] 中的任何位置。

use std::collections::VecDeque;

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

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

相關用法


注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 std::collections::VecDeque.binary_search_by_key。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。