| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 458 人关注过本帖
标题:新学的知识,但是看不懂代码,求教
只看楼主 加入收藏
笔墨痕干
Rank: 1
等 级:新手上路
威 望:1
帖 子:56
专家分:0
注 册:2014-3-24
结帖率:84.21%
收藏
已结贴  问题点数:20 回复次数:3 
新学的知识,但是看不懂代码,求教
#include<stdio.h>
#include<stdlib.h>
typedef char ElemType;
typedef struct BNode
{
    ElemType data;
    struct BNode *lchild;
    struct BNode *rchild;
}BTNode;
typedef BTNode* BinTree;
BinTree CreateBT()
{
  BTNode *p,*q;
  int i,j;
  ElemType x;
  BTNode *ptr[20];
  BinTree root=NULL;//定义根指针,同时也是树的初始化
  printf("\n i,x=");
  scanf("%d%c",&i,&x);//输入第一个元素和第一个值。
  while((i!=0)&&(x!=0))
  {
      q=(BTNode*)malloc(sizeof(BTNode));//申请新的结点
      q->data=x;
      q->lchild=NULL;
      q->rchild=NULL;
      ptr[i]=q;//    ?
      if(i==1)
          root=q;
      else//计算子树的位置。偶数为左子树。奇数为右子树
      {
          j=i/2;
          if((i%2)==0)
              ptr[j]->lchild=q;
          else
              ptr[j]->rchild=q;
      }
      printf("\n i,x=");
      scanf("%d%c",&i,&x);
  }
  return root;
}
void PreOrder(BinTree root)
{
    if(root!=NULL)
    {
        printf("%c",root->data);
        PreOrder(root->lchild);
        PreOrder(root->rchild);
    }
}
void InOrder(BinTree root)
{
    if(root!=NULL)
    {
        InOrder(root->lchild);
        printf("%c",root->data);
        InOrder(root->rchild);
    }
}
void PostOrder(BinTree root)
{
    if(root!=NULL)
    {
        PostOrder(root->lchild);
        PostOrder(root->rchild);
        printf("%c",root->data);
    }
}
void main()
{
    BinTree root;
    root=CreateBT();
    printf("先序序列:");
    PreOrder(root);
    printf("\n");
    printf("中序序列:");
    InOrder(root);
    printf("\n后序序列:");
    PostOrder(root);
    printf("\n");
}
能不能给解释一下这个代码?刚开始学树,只学慨念没学代码,实在看不明白,特别疑惑的是结点与结点之间怎么连接的?请帮忙翻译下吧,尽可能详细点!!谢谢!!!!
搜索更多相关主题的帖子: include 知识 元素 
2014-06-06 19:29
zuiaiqin1205
Rank: 2
等 级:论坛游民
帖 子:5
专家分:30
注 册:2014-6-6
收藏
得分:10 
每个节点有2个指针,称左孩子和右孩子,如果是个完全二叉树,左右孩子都指向不同的1个节点,依次类推
画个图:    1
           / \
           2  3
          /\  /\
         4  5 6  7
2014-06-06 20:07
pauljames
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:千里冰封
威 望:9
帖 子:1555
专家分:10000
注 册:2011-5-8
收藏
得分:5 
《C Primer Plus》上高级数据结构里面,有个二叉树的例子,有讲解

经常不在线不能及时回复短消息,如有c/单片机/运动控制/数据采集等方面的项目难题可加qq1921826084。
2014-06-07 05:50
砖家的谎言
Rank: 12Rank: 12Rank: 12
等 级:禁止访问
威 望:30
帖 子:693
专家分:3898
注 册:2013-12-6
收藏
得分:5 
二叉树,基本知识没理解,先多看下书

我不是砖家,要努力成为砖家。
2014-06-07 08:02
快速回复:新学的知识,但是看不懂代码,求教
数据加载中...
 
   



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

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