04 P5018 对称二叉树

04 P5018 对称二叉树

https://www.luogu.com.cn/problem/P5018

题意

  • 对称二叉树包括

    • 对称节点的值相等
    • 对称结构一致

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bwyLxw9d-1593175807972)(../../../../../%E5%9D%9A%E6%9E%9C%E5%90%8C%E6%AD%A5%E6%96%87%E4%BB%B6%E5%A4%B9/%E6%88%91%E7%9A%84%E5%9D%9A%E6%9E%9C%E4%BA%91/%E7%AE%97%E6%B3%95%E5%88%B7%E9%A2%98%E7%AC%94%E8%AE%B0/noip%E6%99%AE%E5%8F%8A/2018%E5%B9%B4%E6%99%AE%E5%8F%8A%E7%BB%84/04%20P5018%20%E5%AF%B9%E7%A7%B0%E4%BA%8C%E5%8F%89%E6%A0%91.assets/1593091790644.png)]

  • 问给出一个二叉树,找到这个二叉树中。最多节点的对称二叉树。

例如:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xrYdpOdP-1593175807975)(04 P5018 对称二叉树.assets/1593091935346.png)]

想法

  • 暴力+递归
  • 递归思想:
    • 出口条件
      • 如果到了最后一个节点
      • 如果不满足对称结构
    • 返回
      • 递归返回是否是 对称结构
    • 当前状态
      • 左右孩子如果满足对称结构
      • 那么左孩子的右,和右孩子的左对称吗?

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JD52siLK-1593175807976)(04 P5018 对称二叉树.assets/1593092422584.png)]

// P5018 对称二叉树
// Created by majoe on 2020/6/25.
//https://www.luogu.com.cn/problem/P5018

#include <bits/stdc++.h>
using namespace std;
const int N = 10e6+10;
int n,val[N],ch[N][2];
bool flag = true;
int res;
//判断左右节点是否对称
void check(int l ,int r){
    if(!flag) return; // 剪枝
    if (l == -1 && r == -1) return; //遍历到最底层了,返回
    //如果结构不对称,或者值不相等
    if (l == -1 || r == -1 || val[l] != val[r]){
        flag = false;
        return;
    }
    check(ch[l][0],ch[r][1]);
    check(ch[l][1],ch[r][0]);
    return;
}

//统计节点x为根的树的节点数
int cnt(int x){
    int num = 0;
    if(ch[x][0] != -1) num += cnt(ch[x][0]);
    if(ch[x][1] != -1) num += cnt(ch[x][1]);
    return num + 1;//加上根节点
}
int main(){
    cin >> n;
    for (int i = 1; i <= n; ++i) {
        cin >> val[i];
    }
    for (int i = 1; i <= n; ++i) {
        int l,r;
        cin >> l >> r;
        ch[i][0] = l; ch[i][1]=r;
    }

    //遍历每个人访问
    for (int i = 1; i <= n; ++i) {
        flag = true;//先假设是对称的
        check( ch[i][0], ch[i][1]);
        if(flag){//如果为对称树
            res = max(res,cnt(i));
        }
    }

    cout << res;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对称二叉树是一种特殊的二叉树,它的左子树和右子树镜像对称。下面是一份使用 C++ 实现对称二叉树判断的代码: ```c++ #include<iostream> using namespace std; struct TreeNode { int val; TreeNode *left; TreeNode *right; TreeNode(int x) : val(x), left(NULL), right(NULL) {} }; bool isSymmetric(TreeNode* root) { if (!root) return true; return isSymmetric(root->left, root->right); } bool isSymmetric(TreeNode* left, TreeNode* right) { if (!left && !right) return true; if (!left || !right) return false; if (left->val != right->val) return false; return isSymmetric(left->left, right->right) && isSymmetric(left->right, right->left); } int main() { TreeNode* root = new TreeNode(1); root->left = new TreeNode(2); root->right = new TreeNode(2); root->left->left = new TreeNode(3); root->left->right = new TreeNode(4); root->right->left = new TreeNode(4); root->right->right = new TreeNode(3); bool res = isSymmetric(root); if (res) cout << "This is a symmetric binary tree." << endl; else cout << "This is not a symmetric binary tree." << endl; return 0; } ``` 在上面的代码中,我们使用了递归的方法来实现对称二叉树的判断。如果一个二叉树对称二叉树,那么它的左子树和右子树一定是镜像对称的。因此,我们可以递归地比较左子树的左子树和右子树的右子树,以及左子树的右子树和右子树的左子树是否相等。如果相等,则说明这个二叉树对称二叉树

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值