gpt4 book ai didi

iterator - 如何在包含枚举索引的二维数组上返回迭代器?

转载 作者:行者123 更新时间:2023-11-29 08:15:49 25 4
gpt4 key购买 nike

我有一个包含二维数组的结构:

struct Block;

struct World {
blocks: [[Block; 10]; 10],
}

我如何编写一个函数来返回二维数组上的迭代器,但包含枚举索引?

fn enumerate_blocks(&self) -> impl Iterator<Item = (usize, usize, &Block)>

我设法编写了一个函数的实现,它只返回一个没有枚举索引的迭代器:

fn blocks(&self) -> impl Iterator<Item = &Block> {
self.blocks.iter().flat_map(|x| x.iter())
}

如果我调用 Iterator::enumerate一次,我将在 (usize, [B; 10]) 上获得一个迭代器。接下来我可以做什么来获取 (usize, usize, B) 上的迭代器?

我知道我可以让函数返回自定义结构然后实现 Iterator,就像 image 那样,但理想情况下我想避免这种情况。

最佳答案

If I call Iterator::enumerate once, I will get an iterator over (usize, [B; 10])s. What I can do next to get an iterator over (usize, usize, B)s?

调用Iterator::enumerate以同样的方式在内部数组上,继续使用 Iterator::flat_map将它们结合起来。使用 Iterator::map将外部索引添加到内部元组。

#[derive(Debug, Default)]
struct Block;

#[derive(Debug, Default)]
struct World {
blocks: [[Block; 2]; 3],
}

impl World {
fn blocks(&self) -> impl Iterator<Item = (usize, usize, &Block)> {
self.blocks
.iter()
.enumerate()
.flat_map(|(x, v)| v.iter().enumerate().map(move |(y, v)| (x, y, v)))
}
}

fn main() {
let w = World::default();
for (x, y, v) in w.blocks() {
println!("{}, {}, {:?}", x, y, v)
}
}
0, 0, Block
0, 1, Block
1, 0, Block
1, 1, Block
2, 0, Block
2, 1, Block

关于iterator - 如何在包含枚举索引的二维数组上返回迭代器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52339851/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com