判断是否是完全二叉树?

【问题描述】
给定一个树,请你判断它是否是完全二叉树。

【输入格式】
第一行包含整数 N,表示树的结点个数。
树的结点编号为 0∼N−1。
接下来 N 行,每行对应一个结点,并给出该结点的左右子结点的编号,如果某个子结点不存在,则用 - 代替。

【输出格式】
如果是完全二叉树,则输出 YES 以及最后一个结点的编号。
如果不是,则输出 NO 以及根结点的编号。

【数据范围】
1≤N≤20

【输入样例1】
9
7 8
- -
- -
- -
0 1
2 3
4 5
- -
- -

【输出样例1】
YES 8

【输入样例2】
8
- -
4 5
0 6
- -
2 3
- 7
- -
- -

【输出样例2】
NO 1

【算法代码】

#include <bits/stdc++.h>
using namespace std;

const int N=25;

int n;
int le[N],ri[N];
bool has_father[N];
int maxk,maxid;

void dfs(int u, int k) {
	if(u==-1) return;

	if(k>maxk) {
		maxk=k;
		maxid=u;
	}

	dfs(le[u], k*2);
	dfs(ri[u], k*2+1);
}

int main() {
	memset(le,-1,sizeof(le));
	memset(ri,-1,sizeof(ri));

	cin>>n;
	for(int i=0; i<n; i++) {
		string a,b;
		cin>>a>>b;
		if(a!="-") le[i]=atoi(a.c_str()), has_father[le[i]]=true;
		if(b!="-") ri[i]=atoi(b.c_str()), has_father[ri[i]]=true;
	}

	int root=0;
	while(has_father[root]) root++; //find root

	dfs(root,1);

	if(maxk==n) cout<<"YES"<<" "<<maxid;
	else cout<<"NO"<<" "<<root;

	return 0;
}



/*
in1:
9
7 8
- -
- -
- -
0 1
2 3
4 5
- -
- -

out1:
YES 8

--------

in2:
8
- -
4 5
0 6
- -
2 3
- 7
- -
- -

out2:
NO 1
*/



【参考文献】
https://blog.csdn.net/shizheng_Li/article/details/113173597
https://blog.csdn.net/qq_43738331/article/details/115988329
https://www.acwing.com/problem/content/1602/
https://blog.csdn.net/weixin_43847596/article/details/113751978

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值