【题目3】打印二叉树

本文介绍了如何使用C语言实现二叉树的插入、中序遍历、先序遍历和后序遍历。提供了完整的源代码,并展示了在VC6环境下编译和执行的情况。通过示例展示了二叉树的基本操作,强调了递归在解决树结构问题中的重要性。
摘要由CSDN通过智能技术生成

解题思路: 这是一个很经典的题目,几乎所有的数据结构的书上都可以看到

这个问题的解答,这里参考了《数据结构与算法分析---C语言描述》中的描述

方式。

 

打印一颗二叉树最好的方法还是采用递归的方式,其实解决树和图的最基本方法

也是递归,递归有时候会把我们的脑袋转晕了,按照上面那本书中的说法,练习

递归的最好方法就是多看好的递归的例子,然后自己动手去解决一些经典的例子。

 

源代码:(在VC6下通过编译,正确执行)

 

#include <stdio.h>
#include <stdlib.h>
//树节点
struct TreeNode
{
  TreeNode* left;
  TreeNode* right;
  int value;
};
//中序遍历一个颗二叉树

void PrintTree(TreeNode* T)
{
   if(T != NULL)
   {
      PrintTree(T->left);
      printf("%d ",T->value);
      PrintTree(T->right);
   } 
}
//先序遍历一个颗二叉树
void PrintTreeFirst(TreeNode* T)
{
   if(T != NULL)
   {
   printf("%d ",T->value);
      PrintTreeFirst(T->left);
   

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值