NOIP2018-J-4-对称二叉树的题解

原题描述:

题目描述

时间:1s   空间:256M
 

一棵有点权的有根树如果满足以下条件,则被轩轩称为对称二叉树

1. 二叉树;

2. 将这棵树所有节点的左右子树交换,新树和原树对应位置的结构相同且点权相等。

下图中节点内的数字为权值,节点外的id 表示节点编号。

 

现在给出一棵二叉树,希望你找出它的一棵子树,该子树为对称二叉树,且节点数最多。请输出这棵子树的节点数。

注意:只有树根的树也是对称二叉树。本题中约定,以节点T 为子树根的一棵「子树」指的是:节点T 和它的全部后代节点构成的二叉树。

输入格式:

第一行一个正整数 n,表示给定的树的节点的数目,规定节点编号1 \sim n,其中节点 11 是树根。  

第二行 n 个正整数,用一个空格分隔,第 i个正整数 v_i 代表节点i的权值。  

接下来 n 行,每行两个正整数 l_i,r_i​,分别表示节点 i的左右孩子的编号。如果不存在左 / 右孩子,则以-1 表示。两个数之间用一个空格隔开。

输出格式:

输出文件共一行,包含一个整数,表示给定的树的最大对称二叉子树的节点数。

样例1

样例输入1:
2
1 3
2 -1
-1 -1
样例输出1:
1
样例解释 1

最大的对称二叉子树为以节点 2 为树根的子树,节点数为 1。

样例2

样例输入2
10
2 2 5 5 5 5 4 4 2 3
9 10
-1 -1
-1 -1
-1 -1
-1 -1
-1 2
3 4
5 6
-1 -1
7 8
样例输出 2
3
样例解释 2

最大的对称二叉子树为以节点 7 为树根的子树,节点数为 3。

本题约定:

层次:节点的层次从根开始定义起,根为第一层,根的孩子为第二层。树中任一节点的层次等于其父亲节点的层次加 1。 树的深度:树中节点的最大层次称为树的深度。

满二叉树:设二叉树的深度为 ℎ,且二叉树有 2^h -1 个节点,这就是满二叉树。

完全二叉树:设二叉树的深度为 ℎ,除第 ℎ层外,其它各层的结点数都达到最大个数,第 ℎ 层所有的结点都连续集中在最左边,这就是完全二叉树。

 主要思路:

很简单的一题,暴力判断,如果可以,就ans=max(ans,子树节点个数)

check(int l,int r)函数:

如果都是-1,那么return 1;

如果只有一个是-1,那么return 0;

如果权值不同,那么return 0;

否则:

return check(zuo[l],you[r])&&check(you[l],zuo[r]);因为都是对应的

求子树节点个数(dfs)

说了这么多,直接看代码。

请别说我说太少,是因为这题真的很简单。

代码code:

#include<bits/stdc++.h>
using namespace std;
int n,m;
int a[1000010];
int zuo[1000010],you[1000010];
int fa[1000010],zi[1000010];
int root;
//int cnt=0;
bool check(int x,int y)
{if (x == -1&&y == -1){return 1;}if(x == -1||y == -1){return 0;}if(a[x]!=a[y]){return 0;}return ((check(zuo[x],you[y])&&check(you[x],zuo[y])));
}
vector<int> v;
void dfs(int x)
{if(x == root){return ;}zi[fa[x]]++;dfs(fa[x]);
}
int main()
{ios::sync_with_stdio(0);cin.tie(0);int n;cin>>n;for(int i=1;i<=n;i++){cin>>a[i];}for(int i=1;i<=n;i++){cin>>zuo[i]>>you[i];fa[zuo[i]] = i;fa[you[i]] = i;if(zuo[i] == -1&&you[i] == -1){v.push_back(i);}zi[i] = 1;}for(int i=1;i<=n;i++){if(fa[i] == 0){root = i;}}
//	cout<<zi[1]<<'\n';
//	dfs(1);for(int i=1;i<=n;i++){dfs(i);}
//	for(int i=1;i<=n;i++)
//	{
//		cout<<zi[i]<<' ';
//	}
//	cout<<'\n';int ans=0;for(int i=1;i<=n;i++){if(check(zuo[i],you[i])){ans = max(zi[i],ans);}}cout<<ans;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/494185.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【管理咨询宝藏资料27】某岩土集团战略咨询项目方案

本报告首发于公号“管理咨询宝藏”&#xff0c;如需阅读完整版报告内容&#xff0c;请查阅公号“管理咨询宝藏”。 【管理咨询宝藏资料27】某岩土集团战略咨询项目方案 【格式】PDF文件 【关键词】战略规划、对标研究、管理咨询 【文件核心观点】 - 岩土公司公司业务是以技术…

jenkins + gitlab + nginx 自动部署(webhook)

一、意义 当代码仓库被更新时&#xff0c;Jenkins会自动拉取代码进行构建。 适用于测试环境 二、jenkins gitlab nginx 自动部署(webhook) 1.准备服务器 ①安装Jenkins&#xff08;Java17&#xff0c;tomcat9&#xff09; ②安装gitlab &#xff08;16&#xff09; ③…

零基础C++开发上位机--基于QT5.15的串口助手(三)

本系列教程本着实践的目的&#xff0c;争取每一节课都带大家做一个小项目&#xff0c;让大家多实践多试验&#xff0c;这样才能知道自己学会与否。 接下来我们这节课&#xff0c;主要学习一下QT的串口编程。做一款自己的串口助手&#xff0c;那么这里默认大家都是具备串口通信…

office word保存pdf高质量设置

1 采用第三方pdf功能生成 分辨率越大质量越好

文件对比工具Beyond Compare 4 mac v4.4.7(28397)中文版

Beyond Compare是一款适用于Windows、Mac OS X和Linux平台的文件和文件夹比较工具。它可以帮助用户比较和同步文件夹、文件和压缩包等内容&#xff0c;支持多种文件格式&#xff0c;如文本、图像、音频、视频等。 软件下载&#xff1a;Beyond Compare 4 mac v4.4.7(28397)中文版…

WordPress 小程序「星宿UI」基于 uni-app 多端开源优化版

一款基于 WordPress 后台的资讯资源下载小程序&#xff0c;独具一色的 UI 非常好看&#xff0c;独立 PHP 接口。下载地址&#xff1a;优化版.zip

网安渗透攻击作业(3)

sqllabs第46关 order by 注入 一、仔细研究其源码&#xff0c;不难看出id是被放到了order by的后面&#xff0c;如下图所示&#xff1a; 二、尝试用列排序 ?sortusername/password username&#xff1a; password&#xff1a; 不难看出顺序是不同的&#xff0c;如果想要去实…

【非比较排序】计算排序算法

目录 CountSort计数排序 整体思想 图解分析 代码实现 时间复杂度&优缺分析 CountSort计数排序 计数排序是一种非比较排序&#xff0c;不需要像前面的排序一样去比较。 计数排序的特性总结&#xff1a; 1. 计数排序在数据范围集中时&#xff0c;效率很高&#xff0c;但…

k8s pv与pvc理解与实践

参考文章&#xff1a; https://blog.csdn.net/qq_41337034/article/details/117220475 一、 pv/pvc简述 Pv是指PersistentVolume&#xff0c;中文含义是持久化存储卷是对底层的共享存储的一种抽象&#xff0c;Pv由管理员进行配置和创建&#xff0c;只要包含存储能力&#xff…

Three.js-05坐标轴AxesHelper

1.构建对象 说明&#xff1a;参数一表示坐标轴的长度。红色代表 X 轴. 绿色代表 Y 轴. 蓝色代表 Z 轴. const axesHelper new THREE.AxesHelper( 1 ); 2.设置位置 axesHelper.position.y1 axesHelper.position.x1 axesHelper.position.z1 3. 网格 说明&#xff1a;立方体…

水印相机小程序源码

水印相机前端源码&#xff0c;本程序无需后端&#xff0c;前端直接导入即可&#xff0c;没有添加流量主功能&#xff0c;大家开通后自行添加 源码搜索&#xff1a;源码软件库 注意小程序后台的隐私权限设置&#xff0c;前端需要授权才可使用 真实时间地址拍照记录&#xff0c…

进程替换 ——exec族函数、线程

exec函数族 #include <unistd.h> //exec函数族的头文件 int execl(const char *path, const char *arg, ...); int execlp(const char *file, const char *arg, ...); int execle(const char *path, const char *arg, ...,char *const envp[]); int execv(const char *…