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


Rust Iterator.partition_in_place用法及代码示例


本文简要介绍rust语言中 std::iter::Iterator.partition_in_place 的用法。

用法

fn partition_in_place<'a, T, P>(self, predicate: P) -> usize where    T: 'a,    Self: DoubleEndedIterator<Item = &'a mut T>,    P: FnMut(&T) -> bool,

重新排序此迭代器的元素到位根据给定的谓词,使得所有返回的true在所有返回之前false。返回数量true发现的元素。

不维护分区项目的相对顺序。

当前实施

当前的算法尝试找到谓词评估为假的第一个元素,以及它评估为真的最后一个元素并反复交换它们。

时间复杂度:O(n)

另请参见 is_partitioned() partition()

例子

#![feature(iter_partition_in_place)]

let mut a = [1, 2, 3, 4, 5, 6, 7];

// Partition in-place between evens and odds
let i = a.iter_mut().partition_in_place(|&n| n % 2 == 0);

assert_eq!(i, 3);
assert!(a[..i].iter().all(|&n| n % 2 == 0)); // evens
assert!(a[i..].iter().all(|&n| n % 2 == 1)); // odds

相关用法


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