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
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值