L3-016 二叉搜索树的结构 (30 分) 二叉树
二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;它的左、右子树也分别为二叉搜索树。(摘自百度百科)
给定一系列互不相等的整数,将它们顺次插入一棵初始为空的二叉搜索树,然后对结果树的结构进行描述。你需要能判断给定的描述是否正确。例如将{ 2 4 1 3 0 }插入后,得到一棵二叉搜索树,则陈述句如“2是树的根”、“1和4是兄弟结点”、“3和0在同一层上”(指自顶向下的深度相同)、“2是4的双亲结点”、“3是4的左孩子”都是正确的;而“4是2的左孩子”、“1和3是兄弟结点”都是不正确的。
输入格式:
输入在第一行给出一个正整数N(≤),随后一行给出N个互不相同的整数,数字间以空格分隔,要求将之顺次插入一棵初始为空的二叉搜索树。之后给出一个正整数M(≤),随后M行,每行给出一句待判断的陈述句。陈述句有以下6种:
A is the root,即"A是树的根";A and B are siblings,即"A和B是兄弟结点";A is the parent of B,即"A是B的双亲结点";A is the left child of B,即"A是B的左孩子";A is the right child of B,即"A是B的右孩子";A and B are on the same level,即"A和B在同一层上"。
题目保证所有给定的整数都在整型范围内。
输出格式:
对每句陈述,如果正确则输出Yes,否则输出No,每句占一行。
输入样例:
5
2 4 1 3 0
8
2 is the root
1 and 4 are siblings
3 and 0 are on the same level
2 is the parent of 4
3 is the left child of 4
1 is the right child of 2
4 and 0 are on the same level
100 is the right child of 3
输出样例:
Yes
Yes
Yes
Yes
Yes
No
No
No
模拟搜索二叉树即可
#include<bits/stdc++.h>
using namespace std;
//input by bxd
#define rep(i,a,b) for(int i=(a);i<=(b);i++)
#define repp(i,a,b) for(int i=(a);i>=(b);i--)
#define RI(n) scanf("%d",&(n))
#define RII(n,m) scanf("%d%d",&n,&m)
#define RIII(n,m,k) scanf("%d%d%d",&n,&m,&k)
#define RS(s) scanf("%s",s);
#define LL long long
#define pb push_back
#define fi first
#define REP(i,N) for(int i=0;i<(N);i++)
#define CLR(A,v) memset(A,v,sizeof A)
///////////////////////////////////
#define inf 0x3f3f3f3f
#define N 10000
map<int,int>mp;
int a[N];
int n;
void build(void )
{
CLR(a,-);
rep(i,,n)
{
int x;
RI(x);
int id=;
while()
{
if(a[id]==-)
{
a[id]=x;
mp[x]=id;
break;
}
else if(x>a[id])
{
id=id*+;
}
else id*=;
}
}
}
int deep(int x)
{
int d=;
int L=,R=;
if(x==)return ;
while()
{
if(x>=L&&x<=R)
return d; L*=;
R=L*-;
d++;
}
} int main()
{
RI(n);
build();
int q;
RI(q);
string str;
while(q--)
{
int a;
RI(a);
cin>>str;
if(str=="is")
{
cin>>str;
cin>>str;
if(str=="root")
{
if(mp[a]==)
puts("Yes");
else puts("No"); }
else if(str=="parent")
{
cin>>str;
int b;RI(b);
if(mp[b]/==mp[a])
puts("Yes");
else puts("No");
}
else if(str=="left")
{
cin>>str;cin>>str;
int b;RI(b);
if(mp[b]*==mp[a])
puts("Yes");
else puts("No");
}
else if(str=="right")
{
cin>>str;
cin>>str;
int b;RI(b);
if(mp[b]*+==mp[a])
puts("Yes");
else puts("No");
}
}
else if(str=="and")
{
int b;RI(b);
cin>>str;
cin>>str;
if(str=="siblings")
{
if( abs(mp[b]-mp[a])== )
puts("Yes");
else puts("No");
}
else if(str=="on")
{
cin>>str>>str>>str;
if(mp[a]==||mp[b]==)//数据有一些问题 会出现提问的数字不在树里
puts("No");
else if(deep(mp[a])==deep(mp[b]))
puts("Yes");
else puts("No");
}
}
} return ;
}
L3-016 二叉搜索树的结构 (30 分) 二叉树的更多相关文章
- 天梯赛练习 L3-016 二叉搜索树的结构 (30分)
		
题目分析: 用数型结构先建树,一边输入一边建立,根节点的下标为1,所以左孩子为root*2,右孩子为root*2+1,输入的时候可用cin输入字符串也可用scanf不会超时,判断是否在同一层可以判断两 ...
 - PTA 7-2 二叉搜索树的结构(30 分)
		
7-2 二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大 ...
 - 二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历
		
二叉搜索树的结构(30 分) PTA 模拟+字符串处理 二叉搜索树的节点插入和非递归遍历 二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则 ...
 - 二叉搜索树的结构(30 分)  PTA  模拟+字符串处理 二叉搜索树的节点插入和非递归遍历
		
二叉搜索树的结构(30 分) 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大于它的根 ...
 - 【开200数组解决二叉搜索树的建立、遍历】PAT-L3-016. 二叉搜索树的结构——不用链表来搞定二叉搜索树
		
L3-016. 二叉搜索树的结构 二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大于它 ...
 - L3-1 二叉搜索树的结构 (30 分)
		
讲解的很不错的链接:https://blog.csdn.net/chudongfang2015/article/details/79446477#commentBox 题目链接:https://pin ...
 - L3-016 二叉搜索树的结构 (30 分)
		
二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值:它的左.右子树也分别 ...
 - PAT L3-016 二叉搜索树的结构
		
https://pintia.cn/problem-sets/994805046380707840/problems/994805047903240192 二叉搜索树或者是一棵空树,或者是具有下列性质 ...
 - L3-016. 二叉搜索树的结构
		
二叉搜索树或者是一棵空树,或者是具有下列性质的二叉树: 若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值:若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值:它的左.右子树也分别 ...
 
随机推荐
- Bleve代码阅读(一)——新建索引
			
引言 Bleve是Golang实现的一个全文检索库,类似Lucene之于Java.在这里通过阅读其代码,来学习如何使用及定制检索功能.也是为了通过阅读代码,学习在具体环境下Golang的一些使用方式. ...
 - js 碰撞 + 重力 运动
			
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
 - wpc 双工
			
在控制台部署wcf双工 这个可以被silverlight 使用 <?xml version="1.0" encoding="utf-8" ?> &l ...
 - 多文档界面QMdiArea
			
当使用多文档界面功能时,我们是将QMdiArea作为主窗口的中央部件,然后在这个中央部件中,我们可以同时打开很多个子窗口QMdiSubWindow 样式: import sys from PyQt5. ...
 - POJ1751 Highways【最小生成树】
			
题意: 给你N个城市的坐标,城市之间存在公路,但是由于其中一些道路损坏了,需要维修,维修的费用与公路长成正比(公路是直的). 但现有M条公路是完整的,不需要维修,下面有M行,表示不需要维修的道路两端的 ...
 - resolution will not be reattempted until the update interval of repository-group has elapsed or updates are forced
			
Failed to execute goal on project safetan-web: Could not resolve dependencies for project com.safeta ...
 - Python|绝不乱入的靠谱书单
 - C语言表驱动法编程实践
			
数据压倒一切.如果选择了正确的数据结构并把一切组织的井井有条,正确的算法就不言自明.编程的核心是数据结构,而不是算法. ——Rob Pike 说明 本文基于这样的认识:数据是易变的,逻辑是稳定的. ...
 - 使用NGINX+Openresty和unixhot_waf开源防火墙实现WAF功能
			
使用NGINX+Openresty实现WAF功能 一.了解WAF1.1 什么是WAF Web应用防护系统(也称:网站应用级入侵防御系统 .英文:Web Application Firewall,简称: ...
 - zabbix3.0.4报错Get value from agent failed: cannot connect to [[1.1.1.1]:10050]: [4] Interrupted syste
			
一.问题描述 部署完Zabbix agent之后,Server无法获取到数据.报错.报错信息如下: Get value from agent failed: cannot connect to [[1 ...