统计利用先序遍历创建的二叉树中的空链域个数 swustoj

 
  
统计利用先序遍历创建的二叉树中的空链域个数
 1000(ms)
 10000(kb)
 2497 / 4025
利用先序递归遍历算法创建二叉树并计算该二叉树中的空链域个数。先序递归遍历建立二叉树的方法为:按照先序递归遍历的思想将对二叉树结点的抽象访问具体化为根据接收的数据决定是否产生该结点从而实现创建该二叉树的二叉链表存储结构。约定二叉树结点数据为单个大写英文字符。当接收的数据是字符"#"时表示该结点不需要创建,否则创建该结点。最后再统计创建完成的二叉树中的空链域个数。需要注意输入数据序列中的"#"字符和非"#"字符的序列及个数关系,这会最终决定创建的二叉树的形态。
输入
输入为接受键盘输入的由大写英文字符和"#"字符构成的一个字符串(用于创建对应的二叉树)。
输出
输出该用例对应的二叉树中的空链域个数。
样例输入
A##
ABC####
AB##C##
ABCD###EF##G###
A##B##
#A
样例输出
2
4
4
8
2
1

#include<iostream>
#include<stdlib.h>
using namespace std;
typedef struct node
{
char data;
struct node *l,*r;
}Tree;
int obj=0;
void init(Tree *&l)
{
char ch;
cin>>ch;
if(ch=='#') l=NULL;
else
{
l=(Tree *)malloc(sizeof(Tree));
l->data=ch;
init(l->l);
init(l->r);
}
}
void getnode(Tree *&l)
{
if(l)
{
if(l->l==NULL) obj++;
if(l->r==NULL) obj++;
if(l->l!=NULL) getnode(l->l);
if(l->r!=NULL) getnode(l->r);

}
int main()
{
Tree *l;
init(l);
getnode(l);
cout<<obj;
return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
先序遍历创建二叉树的方法如下: 1. 读入根节点的值,创建根节点; 2. 如果剩余的字符不为,则读入下一个字符; 3. 如果下一个字符是字符“#”,则返回上一层; 4. 如果下一个字符不是字符“#”,则创建一个新节点,并将该节点链接到当前节点的左子树上; 5. 递归执行步骤2 - 步骤4,创建当前节点的左子树; 6. 递归执行步骤2 - 步骤4,创建当前节点的右子树。 例如,假设我们要创建二叉树: ``` 1 / \ 2 3 / / \ 4 5 6 ``` 其先序遍历结果为:1 2 4 # # # 3 5 # # 6 # #。 按照上述方法,我们可以在程序实现先序遍历创建二叉树的过程。代码如下: ```python class TreeNode: def __init__(self, val=0, left=None, right=None): self.val = val self.left = left self.right = right def buildTree(preorder): if not preorder: return None root_val = preorder.pop(0) if root_val == "#": return None root = TreeNode(int(root_val)) root.left = buildTree(preorder) root.right = buildTree(preorder) return root preorder = ["1", "2", "4", "#", "#", "#", "3", "5", "#", "#", "6", "#", "#"] root = buildTree(preorder) ``` 在这个例子,我们首先读入根节点的值“1”,创建根节点。然后,我们读入下一个字符“2”,并创建一个新节点,将该节点链接到根节点的左子树上。接着,我们读入下一个字符“4”,发现该字符为“#”,表示当前节点的左子树为,因此返回上一层。接下来,我们回到节点2,读入下一个字符“#”,表示节点2的右子树为,返回上一层。最后,我们回到根节点,读入下一个字符“3”,并创建一个新节点,将该节点链接到根节点的右子树上。依此类推,直到创建完整棵二叉树

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值