前(后)中序求后(前)序

#include <iostream>
#include <fstream>
#include <string>
#include <bits/stdc++.h>
struct TreeNode {
 struct TreeNode* left;
 struct TreeNode* right;
 char  elem;
} T;
TreeNode *BinaryTreeFromOrderings(char* inorder, char* preorder, int length) {        //中序先序求后序
 if(length <= 0) {
  return NULL;
 }
 TreeNode* node = new TreeNode;
 node->elem = *preorder;
 int rootIndex = 0;
 for(; rootIndex < length; rootIndex++) {
  if(inorder[rootIndex] == *preorder)
   break;
 }
 node->left = BinaryTreeFromOrderings(inorder, preorder +1, rootIndex);
 node->right = BinaryTreeFromOrderings(inorder + rootIndex + 1, preorder + rootIndex + 1, length - (rootIndex + 1));
 return node;
}
TreeNode *BinaryTreeFromOrdering(char* inorder, char* hou, int length) {               //中序后序求先序
 if(length <= 0) {
  return NULL;
 }
 TreeNode* node = new TreeNode;
 node->elem = *(hou+length-1);
 int rootIndex = 0;
 for(; rootIndex < length; rootIndex++) {
  if(inorder[rootIndex] == *(hou+length-1))
   break;
 }
 node->left = BinaryTreeFromOrdering(inorder, hou, rootIndex);
 node->right = BinaryTreeFromOrdering(inorder + rootIndex + 1, hou + rootIndex, length - rootIndex - 1);
 return node;
}
void houtree(TreeNode *t) {
 if(t == NULL)
  return ;
 houtree(t->left);
 houtree(t->right);
 printf("%c\n",t->elem);
}
void prtree(TreeNode *t) {
 if(t == NULL)
  return ;
 printf("%c\n",t->elem);
 prtree(t->left);
 prtree(t->right);
}
int main() {
 char pr[100];         //="GDAFEMHZ";
 char in[100];              //="ADEFGHMZ";
 char hou[100];          //="AEFDHZMG";
 TreeNode *tree;
 int sw,len;
 printf("先序中序求后序  输入1\n后序中序求先序  输入2\n");
 scanf("%d",&sw);
 switch(sw) {
  case 1:
   printf("请输入二叉树的先序:");
   scanf("%s",&pr);
   len = strlen(pr);
   printf("请输入二叉树的中序:");
   scanf("%s",&in);
   tree = BinaryTreeFromOrderings(in, pr, len);
   printf("后序遍历为\n");
   houtree(tree);
   break;
  case 2:
   printf("请输入二叉树的后序:");
   scanf("%s",&hou);
   len = strlen(hou);
   printf("请输入二叉树的中序:");
   scanf("%s",&in);
   tree = BinaryTreeFromOrdering(in, hou, len);
   printf("先序遍历为\n");
   prtree(tree);
   break;
 }


 return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值