leetcode简单题19 N.100 相同的树 rust描述

rust 复制代码
// [1,2,3] [1,2,3] true
// [1,2] [1,null,2] false
// [1,2,1] [1,1,2] false
use std::rc::Rc;
use std::cell::RefCell;
#[derive(Debug, PartialEq, Eq)]
pub struct TreeNode {
  pub val: i32,
  pub left: Option<Rc<RefCell<TreeNode>>>,
  pub right: Option<Rc<RefCell<TreeNode>>>,
}

impl TreeNode {
  #[inline]
  pub fn new(val: i32) -> Self {
    TreeNode {
      val,
      left: None,
      right: None
    }
  }
}
// 递归解法
pub fn is_same_tree(p: Option<Rc<RefCell<TreeNode>>>, q: Option<Rc<RefCell<TreeNode>>>) -> bool {
    match (p, q) {
        (Some(p_node), Some(q_node)) => {
            let p_borrow = p_node.borrow();
            let q_borrow = q_node.borrow();
            p_borrow.val == q_borrow.val &&
                is_same_tree(p_borrow.left.clone(), q_borrow.left.clone()) &&
                is_same_tree(p_borrow.right.clone(), q_borrow.right.clone())
        }
        (None, None) => true,
        _ => false,
    }
}
// 迭代解法

pub fn is_same_tree2(p: Option<Rc<RefCell<TreeNode>>>, q: Option<Rc<RefCell<TreeNode>>>) -> bool {
    let mut stack = vec![(p, q)];

    while let Some((p, q)) = stack.pop() {
        match (p, q) {
            (Some(p_node), Some(q_node)) => {
                let p_borrow = p_node.borrow();
                let q_borrow = q_node.borrow();
                if p_borrow.val != q_borrow.val {
                    return false;
                }
                stack.push((p_borrow.left.clone(), q_borrow.left.clone()));
                stack.push((p_borrow.right.clone(), q_borrow.right.clone()));
            }
            (None, None) => continue,
            _ => return false,
        }
    }

        true
    }

fn main() {
    //根据[1,2,3] [1,2,3] true编写测试用例
    let tree1 = Some(Rc::new(RefCell::new(TreeNode {
        val:1,
        left:Some(Rc::new(RefCell::new(TreeNode {
            val:2,
            left:None,
            right:None,
        }))),
        right:Some(Rc::new(RefCell::new(TreeNode {
            val:3,
            left:None,
            right:None,
        }))),
    })));
    let tree2 = Some(Rc::new(RefCell::new(TreeNode {
        val:1,
        left:Some(Rc::new(RefCell::new(TreeNode {
            val:2,
            left:None,
            right:None,
        }))),
        right:Some(Rc::new(RefCell::new(TreeNode {
            val:3,
            left:None,
            right:None,
        }))),
    })));
    assert_eq!(is_same_tree(tree1.clone(), tree2.clone()), true);
    assert_eq!(is_same_tree2(tree1.clone(), tree2.clone()), true);
}
相关推荐
崎岖Qiu25 分钟前
leetcode1343:大小为K的子数组(定长滑动窗口)
java·算法·leetcode·力扣·滑动窗口
Shun_Tianyou1 小时前
Python Day25 进程与网络编程
开发语言·网络·数据结构·python·算法
咸甜适中2 小时前
Rust语言序列化和反序列化vec<u8>,serde库Serialize, Deserialize,bincode库(2025年最新解决方案详细使用)
开发语言·后端·rust
Giser探索家2 小时前
什么是2米分辨率卫星影像数据?
大数据·人工智能·数码相机·算法·分类·云计算
jz_ddk3 小时前
[科普] AI加速器架构全景图:从GPU到光计算的算力革命
人工智能·学习·算法·架构
曦月逸霜3 小时前
内部排序算法总结(考研向)
考研·算法·排序算法
仪器科学与传感技术博士4 小时前
Matplotlib库:Python数据可视化的基石,发现它的美
开发语言·人工智能·python·算法·信息可视化·matplotlib·图表可视化
success5 小时前
【爆刷力扣-二叉树】层次遍历
算法
受之以蒙5 小时前
web-sys进阶:事件处理、异步操作与 Web API 实践
笔记·rust·webassembly
寻月隐君6 小时前
Rust NFT 开发实战:构建生产级的 Pinata IPFS 自动化上传工具
后端·rust·github