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_OC11 小时前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安16 小时前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者18 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠1 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
kisshyshy1 天前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635072 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC2 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法