| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 298 人关注过本帖
标题:二叉树顺序存储的前序遍历
只看楼主 加入收藏
nicholasyoo
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2015-11-1
收藏
 问题点数:0 回复次数:1 
二叉树顺序存储的前序遍历
输入数据有两行,第一行为一个正数n(n<=100),表示该二叉树的节点个数。
接下来有n个字符,表示各个位置上的元素,当字符为'#'时表示当前节点为空。
#include <stdio.h>
#include <malloc.h>
#include<string.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;   
typedef char TElemType;
typedef struct BiTNode
{
    TElemType data;
    struct BiTNode *lchild,*rchild;
}BiTNode,*BiTree;
void create(char *tree,int i,int n,BiTree & T)
{   
    if(tree[i]=='#' ||i>=n) T=NULL;
    else
    {
        T=(BiTree)malloc(sizeof(BiTNode));
        T->data=tree[i];
        create(tree,2*i+1,n,T->lchild);
        create(tree,2*i+2,n,T->rchild);
    }
}

void PreOrderTraverse(BiTree T)
{
    if(T==NULL)return;
    printf("%c",T->data);   
    PreOrderTraverse(T->lchild);
    PreOrderTraverse(T->rchild);  
}

int main()
{
    BiTree T;
    int n;
    char tree[101];
    gets(tree);
    n=strlen(tree);
    create(tree,0,n,T);
    PreOrderTraverse(T);
    printf("\n");
    return 0;
}
2015-11-01 20:21
nicholasyoo
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2015-11-1
收藏
得分:0 
输出的时候节点数也输出了,哪里的问题
2015-11-01 20:21
快速回复:二叉树顺序存储的前序遍历
数据加载中...
 
   



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

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