| 网站首页 | 业界新闻 | 群组 | 人才 | 技术文章 | 下载频道 | 博客 | 代码贴 | 编程论坛
共有 215 人关注过本帖
标题:请教一段和二叉树相关代码问题
只看楼主 收藏
moyi516
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2017-11-17
  问题点数:0  回复次数:2   
请教一段和二叉树相关代码问题
void demo{BiTree T}
{
//T是根节点,二叉链表中各个结点存的是字符
//已知c是全局变量,初值为0
  if(T){
       if(T->data>='A' && T->data<='Z')
        {c++;
         printf("%c",T->data);}
       demo (T->lchild);
       demo (T->rchild);
      }
}

这段代码的含义是不是,先计算输出小于A大于Z的结点值,再输出左子树结点值,最后输出右子书结点值,整体就是对二叉树进行先序遍历?
2017-11-17 21:53
neeso
Rank: 2
等 级:论坛游民
帖 子:3
专家分:10
注 册:2017-11-15
  得分:0 
我也刚学二叉树,
应该是的吧,
但是if(T)这句能编译通过?
有点不确定
2017-12-22 12:04
林月儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:湖南
等 级:版主
威 望:78
帖 子:1431
专家分:6232
注 册:2015-3-19
  得分:0 
程序代码:
if(T){
       if(T->data>='A' && T->data<='Z'){
        c++;
        printf("%c",T->data);}
       demo (T->lchild);
       demo (T->rchild);
      }

这不是先序遍历么,不过,是判断是否在A-Z之间,再执行先序遍历。
判断在前,递归在后。

like wind.
2017-12-22 19:22







关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.068805 second(s), 9 queries.
Copyright©2004-2018, BCCN.NET, All Rights Reserved