| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 579 人关注过本帖
标题:此为由二叉树前序序列和中序序列求后序序列的代码,运行错误,求大神指点错 ...
只看楼主 加入收藏
狂盗一枝梅
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
快速回复:此为由二叉树前序序列和中序序列求后序序列的代码,运行错误,求大神指 ...
数据加载中...
 
   



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

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