我有许多由用户输入指定的 Rust 迭代器,我想以锁步方式进行迭代。
这听起来像是一个类似 的工作Iterator::zip
,只是我可能需要将两个以上的迭代器压缩在一起。我查看了itertools::multizip
和itertools::izip
,但是它们都要求在编译时知道要压缩的迭代器的数量。对于我的任务,要压缩在一起的迭代器数量取决于用户输入,因此在编译时无法知道。
我希望有类似Pythonzip
函数的东西,它需要一个可迭代的可迭代对象。我想函数签名可能看起来像:
fn manyzip<T>(iterators: Vec<T>) -> ManyZip<T>
where
T: Iterator
Run Code Online (Sandbox Code Playgroud)
如何压缩两个以上的迭代器?仅针对编译时已知迭代器数量的情况。
我可以使用索引等解决我的特定问题,只是感觉应该有更好的方法。
Implement your own iterator that iterates over the input iterators and collects them:
struct Multizip<T>(Vec<T>);
impl<T> Iterator for Multizip<T>
where
T: Iterator,
{
type Item = Vec<T::Item>;
fn next(&mut self) -> Option<Self::Item> {
self.0.iter_mut().map(Iterator::next).collect()
}
}
fn main() {
let mz = Multizip(vec![1..=2, 10..=20, 100..=200]);
for v in mz {
println!("{:?}", v);
}
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
387 次 |
最近记录: |