本文简要介绍rust语言中 std::collections::VecDeque.rotate_left 的用法。
用法
pub fn rotate_left(&mut self, mid: usize)将双端队列 mid 位置向左旋转。
等效地,
- 将项目
mid旋转到第一个位置。 - 弹出第一个
mid项目并将它们推到最后。 - 将
len() - mid位置向右旋转。
Panics
如果mid大于len().注意mid == len()做不是Panics并且是no-op轮换。
复杂度
花费*O*(min(mid, len() - mid)) 时间并且没有额外空间。
例子
use std::collections::VecDeque;
let mut buf: VecDeque<_> = (0..10).collect();
buf.rotate_left(3);
assert_eq!(buf, [3, 4, 5, 6, 7, 8, 9, 0, 1, 2]);
for i in 1..10 {
assert_eq!(i * 3 % 10, buf[0]);
buf.rotate_left(3);
}
assert_eq!(buf, [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]);相关用法
- Rust VecDeque.rotate_right用法及代码示例
- Rust VecDeque.remove用法及代码示例
- Rust VecDeque.reserve_exact用法及代码示例
- Rust VecDeque.resize用法及代码示例
- Rust VecDeque.resize_with用法及代码示例
- Rust VecDeque.range_mut用法及代码示例
- Rust VecDeque.reserve用法及代码示例
- Rust VecDeque.retain用法及代码示例
- Rust VecDeque.range用法及代码示例
- Rust VecDeque.binary_search_by_key用法及代码示例
- Rust VecDeque.swap_remove_back用法及代码示例
- Rust VecDeque.contains用法及代码示例
- Rust VecDeque.iter用法及代码示例
- Rust VecDeque.split_off用法及代码示例
- Rust VecDeque.capacity用法及代码示例
- Rust VecDeque.is_empty用法及代码示例
- Rust VecDeque.back用法及代码示例
- Rust VecDeque.new用法及代码示例
- Rust VecDeque.as_mut_slices用法及代码示例
- Rust VecDeque.front用法及代码示例
- Rust VecDeque.try_reserve_exact用法及代码示例
- Rust VecDeque.clear用法及代码示例
- Rust VecDeque.with_capacity_in用法及代码示例
- Rust VecDeque.front_mut用法及代码示例
- Rust VecDeque.try_reserve用法及代码示例
注:本文由纯净天空筛选整理自rust-lang.org大神的英文原创作品 std::collections::VecDeque.rotate_left。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。
