数据结构习题

1.假设二叉树中的每个节点为单个字符,采用二叉链存储设计一个算法findparent,求二叉树b中指定值x的双亲节点。

void findparent(BTNode *b,ElemType x,BTNode *&p) { 
 if (b!=NULL) { 
 if (b->data==x) 
      p=NULL; 
 else if (b->lchild!=NULL && b->lchild->data==x)
  p=b; 
  else if (b->rchild!=NULL && b->rchild->data==x) 
  p=b; 
  else { 
  findparent(b->lchild,x,p);
  if (p==NULL)
    findparent(b->rchild,x,p); 
    }
     } 
     else p=NULL; 
     }

二叉树的主要算法实现都是利用递归,在本题中,首先遍历根节点,之后左节点,右节点,然后左子树,右子树,就可以找到双亲。


2.假设二叉树中的每个节点值为单个字符,采用二叉链的结构存储。设计一个算法,求二叉树b的最小支长。所谓最小最短支长指的是根节点到最近叶子节点的路径长度。

int MinBranch(BTNode *b) {   
int min1 ,min2,min;
 if (b==NULL) return 0; 
 else { 
   if(b->lchild==NULL && b->rchild==NULL)      
   return 0;
    min1=MinBranch(b->lchild);
    min2=MinBranch(b->rchild);
     if(min1<min2) min=min1+1; 
     else
     min=min2+1; returnmin; 
     } 
     }
    ''
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 这道题的要是在假设二叉树每个节点的值为单个字符的情况下,采用二叉存储结构存储。设置一种算法,并使用先序遍历方法输出二叉树B所有结点的层次。 具体解释: 这道题要我们设计一个算法采用二叉存储结构方式存储假设二叉树每个节点的值为单个字符。然后使用先序遍历方法输出二叉树B所有结点的层次。在具体实现过程,我们需要使用二叉表结构来存储这个二叉树B。同时,采用先序遍历的方法来遍历这个二叉树,先访问根节点,然后分别遍历左子树和右子树。在遍历过程,我们可以使用一个计数器来记录当前节点的层次数,当遍历到新的一层时,计数器自增。最终将所有节点的层次数输出即可。 ### 回答2: 先介绍一下什么是二叉树的层次。层次的概念是指二叉树从根节点开始,按照从上到下、从左到右的顺序逐层走过的路径。比如下图所示的二叉树的层次为1,2,2,3,3,3,3。 ![binary_tree.png](https://i.loli.net/2021/08/07/KoH8wCrzXTU2fed.png) 而先序遍历的顺序是先访问根节点、然后访问左子树、最后访问右子树。因此,我们可以利用先序遍历的方法遍历整个二叉树,记录每个节点所在的层次即可。具体实现如下: 1. 从根节点开始,记录当前层次为1; 2. 输出根节点的值,然后递归遍历它的左子树,层次+1; 3. 递归遍历它的右子树,层次保持不变; 4. 重复2~3步骤,直到遍历完整个二叉树。 下面是使用Python实现这个算法的代码: ```python class TreeNode: def __init__(self, val: str, left=None, right=None): self.val = val self.left = left self.right = right def printLevel(root: TreeNode, level: int): if root is None: return if level == 1: print(root.val, end=' ') elif level > 1: printLevel(root.left, level-1) printLevel(root.right, level-1) def preOrderTraverse(root: TreeNode, level: int): if root is None: return print(root.val, end=' ') printLevel(root.left, level+1) preOrderTraverse(root.left, level+1) printLevel(root.right, level+1) preOrderTraverse(root.right, level+1) # test root = TreeNode('A', TreeNode('B', TreeNode('D'), TreeNode('E')), TreeNode('C', TreeNode('F', TreeNode('G')), TreeNode('H'))) preOrderTraverse(root, 1) ``` 在这个代码,我们首先定义了一个TreeNode类,用来表示二叉树的节点。然后定义了两个函数printLevel和preOrderTraverse。函数printLevel用来打印某个节点在第几层,函数preOrderTraverse用来遍历整个二叉树。 需要注意的是,在preOrderTraverse函数,我们需要分别遍历左子树和右子树。在遍历左子树时,层次要加1;在遍历右子树时,层次不变。这是因为左子树的所有节点都在当前节点的下一层,而右子树的所有节点都在当前节点的同一层。如果层次也加1的话,会导致右子树的节点的层次看起来比左子树的节点高1,这显然是不正确的。 运行上面的代码,输出的结果如下: ``` A B C D E F H G 1 2 2 3 3 3 3 ``` 其第一行是按照先序遍历的结果输出的所有节点的值,第二行则是输出的所有节点的层次。这个算法的时间复杂度为O(n^2),其n为二叉树节点的个数。实际应用时,可能需要使用其他更高效的数据结构来记录每个节点的层次,从而减少时间复杂度。 ### 回答3: 二叉树的层次遍历是一种常用的遍历方法,可以按照节点所在的层级顺序遍历整棵树。针对这道题目,可以通过先序遍历的方式,结合递归的特性,实现节点层次的输出。 具体的实现思路如下: 1.定义一个preOrder函数,用于先序遍历整棵树。同时需要添加两个形参,一个是表示当前节点的层次深度depth,另一个是用于存储历史遍历深度的变量lastDepth。 2.先遍历根节点,输出该节点的值,并将lastDepth设为当前节点depth。 3.递归遍历左子树,遍历时将当前节点的深度depth + 1。 4.如果递归过程发现当前节点的深度depth比lastDepth大,则将当前节点的深度赋值给lastDepth,表示已经到达了下一层。 5.递归遍历右子树,与左子树遍历方式类似。 6.按照上述方式遍历完整棵树,即可实现输出节点层次的目标。 下面是具体的代码实现: void preOrder(TreeNode* root, int depth, int& lastDepth) { if (!root) { return; } // 如果当前节点的深度比上一个节点大,则表示到达下一层 if (depth > lastDepth) { lastDepth = depth; } // 输出当前节点的值和层数 cout << root->val << " (" << depth << ")" << endl; // 遍历左子树 preOrder(root->left, depth + 1, lastDepth); // 遍历右子树 preOrder(root->right, depth + 1, lastDepth); } // 主函数调用 int main() { // 构造二叉树,略 // 从根节点开始遍历,深度为1 int lastDepth = 1; preOrder(root, 1, lastDepth); return 0; } 通过上述代码实现,可以实现对二叉树节点深度的输出。需要注意的是,因为本题采用的是先序遍历的方式,因此子树之间的遍历顺序也是先左后右,如果需要按照其他遍历方式输出节点深度,需要相应更改遍历顺序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lonota_zyx

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值