本文简要介绍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。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。