2024王道408数据结构P144 T17

2024王道408数据结构P144 T17

思考过程

  1. 先看题目,让我们判断两棵二叉树是否相似,相似指的是以下三个方面:
    • T1和T2都是空的二叉树或T1和T2都只有一个结点
    • T1的左子树和T2的左子树是相似的,且T1的右子树和T2的右子树是相似的。

题目的意思我们可以简化为两个大类,要么为空要么为非空。

  1. 我们只要判断当前结点是两个都为空还是一个为空另一个不为空就行了,因为如果一个为空另一个不为空则说明这两棵树必不可能相似。如果两个结点都空的话我们函数结果return 1,把一个结点为空另一个结点不空的话函数返回return 0。

代码过程

  1. 正如我们上面所说的,我们需要判断三种情况
    • 如果两个结点都为空的话if(T1 == NULL && T2 == NULL)说明这两棵树必是相似的,我们直接return 1;就好了。
    • 如果两个结点中有一个结点为空if (T1 == NULL || T2 == NULL),另一个结点不为空的话说明这两棵树必不可能相似,我们返回0return 0;
    • 第三种情况就是两个结点都不为空,也就是我们需要用递归来判断剩下的结点是否相似,我们创建两个变量left和right,left用来表示两个结点的左子树是否相似,如果相似的话给我们返回1,不相似则返回0;right也一样,用来表示两个结点的右子树是否相似 。假设我们给函数取名叫similarleft = similar(T1->lchild, T2->lchild); right = similar(T1->rchild, T2->rchild);最后返回的时候我们返回return (left && right);用逻辑与&&,左右两边都为1结果才是1,有0则0。

到这里这题就做完了。

完整代码

cpp 复制代码
//
// Created by 黎圣  on 2023/8/26.
//
/*
 * 试设计判断两颗二叉树是否相似的算法。所谓二叉树T1和T2相似,指的是
 * T1和T2都是空的二叉树
 * 或都只有一个根结点
 * 或T1的左子树和T2的左子树是相似的,且T1的右子树和T2的右子树是相似的。
 */
#include "iostream"
using namespace std;
typedef struct TreeNode
{
    char data;
    struct TreeNode *lchild, *rchild;
}*tree;
void CreateTree(tree &t)
{
    char ch;
    cin >> ch;
    if (ch == '#')
        t = NULL;
    else
    {
        t = (struct TreeNode *)malloc(sizeof(struct TreeNode));
        t->data = ch;
        t->lchild = NULL;
        t->rchild = NULL;
        CreateTree(t->lchild);
        CreateTree(t->rchild);
    }
}
//递归比较左右子树 空+空 = 1 空+非空 = 0
int similar(tree T1, tree T2)
{
    int left, right;
    if (T1 == NULL && T2 == NULL)
        return 1;
    else if (T1 == NULL || T2 == NULL)
        return 0;
    else
    {
        left = similar(T1->lchild, T2->lchild);
        right = similar(T1->lchild, T2->rchild);
        return (left && right);
    }
}
int main()
{
    tree t1, t2;
    CreateTree(t1);
    CreateTree(t2);
    printf("%d", similar(t1, t2));
    return 0;
}

最后感谢b站up主@吸血小金鱼,找工作真难呜呜呜呜呜呜

相关推荐
To_OC7 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与12 小时前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法
复杂网络17 小时前
论最小 Agent 计算机的形态
算法
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷2 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络2 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络2 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4002 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4002 天前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法