二叉树输出(btout)

测试地址:

【题目描述】

树的凹入表示法主要用于树的屏幕或打印输出,其表示的基本思想是兄弟间等长,一个结点的长度要不小于其子结点的长度。二叉树也可以这样表示,假设叶结点的长度为1,一个非叶结点的长度等于它的左右子树的长度之和。

一棵二叉树的一个结点用一个字母表示(无重复),输出时从根结点开始:

每行输出若干个结点字符(相同字符的个数等于该结点长度),

如果该结点有左子树就递归输出左子树;

如果该结点有右子树就递归输出右子树。

假定一棵二叉树一个结点用一个字符描述,现在给出先序和中序遍历的字符串,用树的凹入表示法输出该二叉树。

【输入】

两行,每行是由字母

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了将二叉树输出中缀表达式,我们可以使用中序遍历的方法。中序遍历是通过先遍历左子树,然后输出根节点,最后遍历右子树的方式。在遍历的过程中,我们需要在适当的位置添加括号。 具体算法的实现如下: 1. 如果当前节点为空,直接返回。 2. 如果当前节点是叶子节点,则输出节点的值。 3. 如果当前节点有左子树,则输出左括号。 4. 递归地遍历左子树。 5. 输出当前节点的值。 6. 如果当前节点有右子树,则输出右括号。 7. 递归地遍历右子树。 以下是一个示例的代码实现: ``` void BtreeToExp(BTree *root){ BtreeToExpHelper(root); } void BtreeToExpHelper(BTree *root){ if (root == NULL){ return; } else if (root->left == NULL && root->right == NULL){ printf("%s", root->data); } else { if (root->left != NULL){ printf("("); } BtreeToExpHelper(root->left); printf("%s", root->data); BtreeToExpHelper(root->right); if (root->right != NULL){ printf(")"); } } } ``` 通过以上算法,我们可以将二叉树输出为中缀表达式。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [【数据结构学习笔记】——根据中缀表达式构建二叉树输出](https://blog.csdn.net/henry903/article/details/50617907)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [算法设计:将给定的二叉树输出其等价的中缀表达式](https://blog.csdn.net/m0_46405703/article/details/127449379)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值