【18NOIP普及组】对称二叉树(信息学奥赛一本通 1981)(洛谷 5018)
【题目描述】
一棵有点权的有根树如果满足以下条件,则被轩轩称为对称二叉树:
1.二叉树;
2.将这棵树所有节点的左右子树交换,新树和原树对应位置的结构相同且点权相等。
下图中节点内的数字为权值,节点外的idid表示节点编号。
现在给出一棵二叉树,希望你找出它的一棵子树,该子树为对称二叉树,且节点数最多。请输出这棵子树的节点数。
注意:只有树根的树也是对称二叉树。本题中约定,以节点T为子树根的一棵“子树”指的是:节点T 和它的全部后代节点构成的二叉树。
【输入】
第一行一个正整数nn,表示给定的树的节点的数目,规定节点编号1∼n1∼n,其中节点11是树根。
第二行nn个正整数,用一个空格分隔,第ii个正整数vivi代表节点ii的权值。
接下来nn行,每行两个正整数li,rili,ri,分别表示节点ii的左右孩子的编号。如果不存在左/右孩子,则以−1−1表示。两个数之间用一个空格隔开。
【输出】
输出共一行,包含一个整数,表示给定的树的最大对称二叉子树的节点数。
【输入样例】
2
1 3
2 -1
-1 -1
【输出样例】
1
【样例1说明】
最大的对称二叉子树为以节点 22 为树根的子树,节点数为 11。
【样例输入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说明】
最大的对称二叉子树为以节点 77 为树根的子树,节点数为 33。
【数据规模与约定】
共 2525 个测试点。
vi≤1000vi≤1000。
测试点 1−31−3,n≤10n≤10,保证根结点的左子树所有节都没右孩子,根结点的右孩子,根结点的右子树的所有节点 都没有左孩子。
测试点 4−84−8,n≤10n≤10。
测试点 9−129−12,n≤105n≤105,保证输入是一棵 “满二叉树 ”。
测试点 13−1613−16,n≤105n≤105,保证输入是一棵 “完全二叉树 ”。
测试点 17−2017−20,n≤105n≤105,保证输入的树点权均为 11。
测试点 21−2521−25,n≤106n≤106。
本题约定:
层次:节点的层次从根开始定义起,根为第一层,根的孩子为第二层。树中任一节点的层次等于其父亲节点的层次加11。
树的深度:树中节点的最大层次称为树的深度。
满二叉树:设二叉树的深度为hh,且二叉树有2h−12h−1个节点,这就是满二叉树。
|
|
满二叉树(深度为 3) |
完全二叉树:设二叉树的深度为h,除第h层外,其它各层的结点数都达到最大个数,第h层所有的结点都连续集中在最左边,这就是完全二叉树。
|
|
|
完全二叉树(深度为 3) |
完全二叉树(深度为 3) |
刚开始看到这道题的时候我居然傻乎乎的用指针去写!!!还邻接链表!真的够沙雕了( Ĭ ^ Ĭ )
然后在纸上写了一番后想到如果一棵二叉树的中序遍历是回文的话那就一定是对称二叉树,然鹅这道题并不是要我们判断某棵树是否为对称二叉树,而是要我们求给定的树的最大对称二叉子树的节点数!!所以我就gg了...然后脑子里一片空白,慌得一批
后来去网上看了别人的题解后觉得也不那么难嘛,直接跑暴力就能过!!ε=(´ο`*)))唉现在说什么都晚了,那个时候怎么就没想到呢
直接上代码:
#include <bits/stdc++.h>
using namespace std;
const int SIZE=;
const int INF=0x3f3f3f3f;
#define ll long long struct Tree{
int v,Left_Child,Right_Child;
}tree[SIZE]; void DFS(int L,int R); int n,sum=,ans=;
bool F=true; int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++) scanf("%d",&tree[i].v);
for (int i=;i<=n;i++) scanf("%d%d",&tree[i].Left_Child,&tree[i].Right_Child); for (int i=;i<=n;i++){
F=true;
sum=;
DFS(tree[i].Left_Child,tree[i].Right_Child);
if (F) ans=max(ans,sum);
} cout<<ans; return ;
} void DFS(int L,int R)
{
if (F==false) return;
if (L==- && R==-) return;
if ((L==- && R!=-) || (L!=- && R==-)){
F=false;
return;
} if (tree[L].v==tree[R].v){
sum+=;
DFS(tree[L].Left_Child,tree[R].Right_Child);
DFS(tree[L].Right_Child,tree[R].Left_Child);
}
else{
F=false;
return;
}
}
再来个详细点的:
#include<bits/stdc++.h>
using namespace std;
int v[],lc[],rc[],cn[];
int n,mi,nu;
bool f;
int read()
{
char c;int ff=;
while((c=getchar())<''||c>'')
if(c=='-')ff=-;
int num=c-'';
while((c=getchar())>=''&&c<='')
num=num*+c-'';
return ff*num;
}
int c(int i)
{
if(cn[i])return cn[i];
long long sum=;
if(lc[i]!=-)sum+=c(lc[i]);
if(rc[i]!=-)sum+=c(rc[i]);
return cn[i]=sum;
}
void work(int x,int y)
{
if(x==-&&y==-)return;
if(x==-||y==-||v[x]!=v[y])
{
f=false;return ;
}
work(lc[x],rc[y]);
work(rc[x],lc[y]);
}
int main()
{
freopen("tree.in","r",stdin);
freopen("tree.out","w",stdout);
cin>>n;
for(int i=;i<=n;i++)
v[i]=read();
for(int i=;i<=n;i++)
{
lc[i]=read();rc[i]=read();
}
int ans=;
for(int i=;i<=n;i++)
if(lc[i]!=-&&rc[i]!=-&&v[lc[i]]==v[rc[i]])
{
f=true;
work(lc[i],rc[i]);
if(f)ans=max(ans,c(i));
}
cout<<ans;
return ;
}
【18NOIP普及组】对称二叉树(信息学奥赛一本通 1981)(洛谷 5018)的更多相关文章
- P5018 [NOIP2018 普及组] 对称二叉树
P5018 [NOIP2018 普及组] 对称二叉树 题目 P5018 思路 通过hash值来判断左右树是否相等 \(hl[i]\) 与 \(Hl[i]\) 是防止hash冲突, \(r\) 同理 注 ...
- $ybt\ 【信息学奥赛一本通】题解目录$
[信息学奥赛一本通]题解目录 $ \large -> OJ$ $ problem1000 $ \(Answer\) - > $ \large 1000$ $ problem1001 $ \ ...
- 【03NOIP普及组】栈(信息学奥赛一本通 1924)(洛谷 1044)
#include<bits/stdc++.h> using namespace std; int n,ans,m,k,ans2; ],f[],d[][],num[][],tmp[],s[] ...
- 【00NOIP普及组】计算器的改良(信息学奥赛一本通 1910)(洛谷 1022)
[题目描述] NCL是一家专门从事计算器改良与升级的实验室,最近该实验室收到了某公司所委托的一个任务:需要在该公司某型号的计算器上加上解一元一次方程的功能.实验室将这个任务交给了一个刚进入的新手ZL先 ...
- 【04NOIP普及组】火星人(信息学奥赛一本通 1929)(洛谷 1088)
[题目描述] 人类终于登上了火星的土地并且见到了神秘的火星人.人类和火星人都无法理解对方的语言,但是我们的科学家发明了一种用数字交流的方法.这种交流方法是这样的,首先,火星人把一个非常大的数字告诉人类 ...
- 【03NOIP普及组】麦森数(信息学奥赛一本通 1925)(洛谷 1045)
[题目描述] 形如2P-1的素数称为麦森数,这时P一定也是个素数.但反过来不一定,即如果P是个素数,2P-1不一定也是素数.到1998年底,人们已找到了37个麦森数.最大的一个是P=3021377,它 ...
- 【06NOIP普及组】数列(信息学奥赛一本通 1937)(洛谷 1062)
[题目描述] 给定一个正整数k(3≤k≤15),把所有k的方幂及所有有限个互不相等的k的方幂之和构成一个递增的序列,例如,当k=3时,这个序列是: 1,3,4,9,10,12,13,… (该序列实际上 ...
- 【00NOIP普及组】税收与补贴问题(信息学奥赛一本通 1911)( 洛谷 1023)
[题目描述] 每样商品的价格越低,其销量就会相应增大.现已知某种商品的成本及其在若干价位上的销量(产品不会低于成本销售),并假设相邻价位间销量的变化是线性的且在价格高于给 定的最高价位后,销量以某固定 ...
- 【09NOIP提高组】Hankson 的趣味题(信息学奥赛一本通 1856)(洛谷 1072)
题目描述 Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家,他的儿子名叫Hankson.现在,刚刚放学回家的Hankson 正在思考一个有趣的问题.今天在课堂上,老师讲解了如何求 ...
随机推荐
- JDBC简单增删改查实现(单表)
0.准备工作 开发工具: MySQL数据库, intelliJ IDEA2017. 准备jar包: mysql-connector-java-5.1.28-bin.jar(其他均可) 1. 数据库数据 ...
- iOS网络请求之数据解析
JSON解析 IOS中Json解析的四种方法 NSURLConnection-网络请求浅析 IOS开发:官方自带的JSON使用 XML 解析 GDataXMLNode应用 IOS学习:常用第三方库(G ...
- 知识扩展——(转)一篇文章彻底弄懂Base64编码原理
在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇博文带领大家了解一下Base64的底层实现. 一.Base64的由来 目前Base64已经成 ...
- linux技能点 二
三. 文件操作:新增,删除,修改,查找,文件属性,文件内容查看,文件辅助命令,打包(解压缩),文件名注意事项. 新增:单文件,目录 ...
- RabbitMq 消息队列 在Python端的应用
https://www.cnblogs.com/Xuuuuuu/p/10895552.html rabbit_server持久化,消费者端手动确认保证消息不会丢失.具体代码如下: 1对1生产者端代码: ...
- JS 对象 数组求并集,交集和差集
一.JS数组求并集,交集和差集 需求场景 最近,自己项目中有一些数组操作,涉及到一些数学集的运算,趁着完成后总结一下. 简化问题之后,现有两数组a = [1, 2, 3],b = [2, 4, 5], ...
- css display block 和 inline
根据CSS规范的规定,每一个网页元素都有一个display属性,用于确定该元素的类型,每一个元素都有默认的display属性值,比如div元素,它的默认display属性值为“block”,成为“块级 ...
- Python3链接Oracle
1. 说明 本篇主要参见与cx_Oracle安装 全部操作均在root用户下完成 2. 下载Oracle Instant Client客户端 依据系统,在Oracle Instant Client下载 ...
- 【HCIA Gauss】学习汇总-数据库管理(SQL语法 库表 索引操作)-5
# 简单查询select * from table_reference # 创建表 create table TB(staff_id int primary key , course_name cha ...
- Python+Selenium+Appium对APP进行UI自动化测试
1. 安装Python3.7版本 pythonjava的JDK java -version javac nodejs node --versionappium 若nodejs安装完毕,使用npm安装a ...




