首页 > 其他分享 >0033-Rust-实现递归迭代

0033-Rust-实现递归迭代

时间:2022-08-29 18:16:03浏览次数:82  
标签:Node 递归 迭代 0033 values vec children Rust

环境

  • Time 2022-05-21
  • Rust 1.61.0

前言

说明

参考:https://fasterthanli.me/articles/recursive-iterators-rust

目标

对于递归类型的结构,实现递归迭代。

自定义类型

struct Node<T> {
    values: Vec<T>,
    children: Vec<Node<T>>,
}

values

impl<T> Node<T> {
    pub fn values<'a>(&'a self) -> Box<dyn Iterator<Item = &T> + 'a> {
        let chain = self.children.iter().map(|n| n.values()).flatten();
        Box::new(self.values.iter().chain(chain))
    }
}

使用迭代器

fn main() {
    let node = Node {
        values: vec![1, 2, 3],
        children: vec![
            Node {
                values: vec![4, 5, 6],
                children: vec![],
            },
            Node {
                values: vec![7, 8, 9],
                children: vec![],
            },
        ],
    };

    for ele in node.values() {
        println!("{ele:?}")
    }
}

总结

对递归类型的结构体,实现了递归迭代。

附录

标签:Node,递归,迭代,0033,values,vec,children,Rust
From: https://www.cnblogs.com/jiangbo4444/p/16636861.html

相关文章

  • Rust极简教程
    据说,Rust语言语法的高门槛是劝退很多人上手的主要原因。确实,Rust语言希望解决C/C++手工管理内存的问题,但是又不想引入类似golang,java的GC机制。因此,为了能让编译器能够......
  • 0025-Rust-自实现迭代器
    环境Time2022-05-21Rust1.61.0前言说明参考:https://doc.rust-lang.org/std/iter/trait.IntoIterator.html目标前一节自定义了一个类型来实现迭代器,并且自定义了......
  • 0023-Rust-自实现迭代器
    环境Time2022-05-19Rust1.60.0前言说明参考:https://doc.rust-lang.org/std/iter/index.html目标针对自定义类型,实现一个迭代器。自定义类型#[derive(Default,......
  • 我在 Rust 中的第一个真实代码
    我在Rust中的第一个真实代码每种语言都始于游乐场。你可以在那里做一些令人惊奇的事情,但它们就像邻近的儿童沙饼一样令人惊奇。一旦你从操场进入“做一些真正的事情”,......
  • Rust学习笔记-初识
    很早以前,看到马斯克说:“我是Rust的粉丝,但是为了性能会选择C。”之后就对Rust产生了一些兴趣,不过由于时间关系没有及时深入了解。最近,又看到Meta选定四种编程语言作为首选......
  • es6——iterator迭代器
    iterator的说明1es6创建了一种新的迭代器2forof可以遍历使用迭代器3ArrayArgumentsSetMapStringTypeArrayNodeList都支持4iterator是对象的一个symbol类......
  • Python基础——迭代器 生成器
    迭代器iterator迭代简单理解就是重复,但是每次重复产生的结果还要作为下次重复的初始值。可迭代对象:含有——iter——方法的对象。可以用for...in..遍历的都是可迭代对......
  • 正确的策略迭代流程是什么?
    当前已经有了一版线上用户正在使用的方案,然后算法对某些策略做了模型迭代或者规则优化(反映在cxr或者更好的用户体验)产生了一版新的方案,新方案的上线流程是怎样的?方式一:新......
  • Rust-语句和表达式
    语句和表达式Rust的函数体是由一系列语句组成,最后由一个表达式来返回值,例如:fnadd_with_extra(x:i32,y:i32)->i32{letx=x+1;//语句lety=y+......
  • 关于 map 的迭代器
     今天遇到一个问题CountCompileResult(constLIST_MAP&rfLmCompileWafers){    for(autoitr=rfLmCompileWafers.begin();itr!=rfLmCompileWafers.e......