标题:此为由二叉树前序序列和中序序列求后序序列的代码,运行错误,求大神指点错 ...
只看楼主
狂盗一枝梅
Rank: 1
等 级:新手上路
帖 子:8
专家分:0
注 册:2012-12-23
结帖率:0
 问题点数:0 回复次数:0 
此为由二叉树前序序列和中序序列求后序序列的代码,运行错误,求大神指点错在哪里
程序代码:
#include<iostream>
#include<stdlib.h>
#include<stdio.h>
#include<string.h>
using namespace std;
typedef struct vode
{
    char date;
    struct vode *l,*r;
}bitree;
void getpreordertraverse(bitree *root,char pre[],char in[],int ps,int s,int n);
void postordertraverse(bitree *root);
int main()
{
    int zong ;
    cin>>zong;
    while(zong--)
    {
        char pre[100],in[100];
        cin>>pre>>in;
        int len=strlen(pre);
        bitree *root;
        getpreordertraverse(root,pre,in,0,0,len);
        postordertraverse(root);
        cout<<endl;
    }
    return 0;
}
void getpreordertraverse(bitree *root,char pre[],char in[],int ps,int s,int n)
{
      if(n==0)root=NULL;
      else 
      {
          root=(bitree *)malloc(sizeof(bitree));
          root->date=pre[ps];
          int k;
          for(k=s;k<=s+n-1;k++)
              if(in[k]==pre[ps])
                  break;
          getpreordertraverse(root->l,pre,in,ps+1,s,k-s); 
          getpreordertraverse(root->r,pre,in,ps+1+(k-s),k+1,n-(k-s)-1);
      }
}
void postordertraverse(bitree *root)
{
    if(root)
    {
        postordertraverse(root->l);
        postordertraverse(root->r);
        cout<<root->date;
    }
}
    
搜索更多相关主题的帖子: 二叉树 
2013-11-07 20:02



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




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

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