标题:由先序序列、中序序列构建二叉树,大家看看这个程序问题出在什么地方了?
取消只看楼主
YAOYINGCHONG
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-11-21
结帖率:0
已结贴  问题点数:4 回复次数:0 
由先序序列、中序序列构建二叉树,大家看看这个程序问题出在什么地方了?
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 100
typedef struct node
{
char data;
struct node *lchild,*rchild;
}BiNode;
void createBiTree(BiNode *root,char a[],int a_start,int a_end,char b[],int b_start,int b_end)
{
    int k;
    char ch;
    if(a_start>a_end)
        root=NULL;
    else
    {
        ch=a[a_start];
        k=b_start;
        while(b[k]!=ch)
            k++;
        root=(BiNode *)malloc(sizeof(BiNode));
        root->data=ch;
        createBiTree(root->lchild,a,a_start+1,a_start+k-b_start,b,b_start,k-1);
        createBiTree(root->rchild,a,a_start+k-b_start+1,a_end,b,k+1,b_end);
    }
}
void preorder(BiNode *root)
{
    if(root!=NULL)
    {printf("%c",root->data);
    preorder(root->lchild);
    preorder(root->rchild);
    }
}
void inorder(BiNode *root)
{
    if(root)
    {
        inorder(root->lchild);
            printf("%c",root->data);
            inorder(root->rchild);
    }
}
void main()
{
    char a[N],b[N];
    BiNode *root;
    printf("输入先序序列:");
    gets(a);
    printf("输入中序序列:");
    gets(b);
    createBiTree(root,a,0,strlen(a)-1,b,0,strlen(b)-1);
    printf("\n先序序列:");
    preorder(root);
    printf("\n中序序列:");
    inorder(root);
    printf("\n");
}


搜索更多相关主题的帖子: include 二叉树 
2012-11-21 15:33



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-387814-1-1.html




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

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