我有两个Vec
,它们可以是不同的长度,例如:
let xs = vec![1, 2, 3, 4, 5];
let ys = vec![11, 12, 13];
字符串
我想把它们成对地打印出来:
x=1, y=11
x=2, y=12
x=3, y=13
x=4; no matching Y
x=5; no matching Y
型
我可以使用Iterator::zip
来获取xs
和ys
中具有匹配元素的对:
for (x, y) in xs.iter().zip(ys.iter()) {
println!("x={}, y={}", x, y);
}
型
但是对于“不匹配”的位,我需要复杂的代码来检查长度并取剩余的一部分。
我想要一个完全基于迭代器的解决方案,所以我尝试了:
let mut it_xs = xs.iter();
let mut it_ys = ys.iter();
while let (Some(x), Some(y)) = (it_xs.next(), it_ys.next()) {
println!("x={}, y={}", x, y);
}
while let Some(x) = it_xs.next() {
println!("x={}, no matching Y", x);
}
while let Some(y) = it_ys.next() {
println!("y={}, no matching X", y);
}
型
这并不正确,因为第一个循环跳过了第一个在另一个列表中没有匹配的元素(x=4)。
有没有可能在迭代器的帮助下求解,而不对较大的Vec
的其余部分进行切片?
2条答案
按热度按时间j2cgzkjk1#
无外部板条箱的实施:
字符串
i34xakig2#
itertools
有一个方法zip_longest
,它就是这样做的:字符串