数据结构 前序中序求二叉树

举报
悦来客栈的老板 发表于 2020/12/28 23:13:01 2020/12/28
【摘要】 #include <stdio.h>#include <stdlib.h>#include <string.h> #define OK 1#define ERROR 0#define OVERFLOW -2 typedef char TElemType; typedef struct BiNode{ TElemType data; stru...

  
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. #define OK 1
  5. #define ERROR 0
  6. #define OVERFLOW -2
  7. typedef char TElemType;
  8. typedef struct BiNode
  9. {
  10. TElemType data;
  11. struct BiNode *lchild,*rchild;
  12. }BiNode, *BiTree;
  13. void PostOrderTraverse(const char *preStart, const char *preEnd, const char *inStart, const char *inEnd,BiTree &T)
  14. {
  15. char root = *preStart;
  16. int len = preEnd - preStart,i = 0;
  17. T = (BiTree)malloc(sizeof(BiNode));
  18. T->data = root;
  19. for(;*(inStart+i) != root && i<=len; i++); //查找根结点在中序的位置
  20. if (i != 0)
  21. {//如果不是第一个,说明其含有左子树
  22. PostOrderTraverse(preStart+1, preStart+i, inStart, inStart+i-1,T->lchild);
  23. }
  24. else
  25. {
  26. T->lchild = NULL;
  27. }
  28. if (i != len)
  29. {//如果不是最后一个,说明其含有右子树
  30. PostOrderTraverse(preStart+i+1, preEnd, inStart+i+1, inEnd,T->rchild);
  31. }
  32. else
  33. {
  34. T->rchild = NULL;
  35. }
  36. }
  37. void PreOrderTraverse(BiTree T)
  38. {//先序遍历的递归调用
  39. if (T == NULL)
  40. {
  41. return;
  42. }
  43. printf("%c",T->data);//访问根结点
  44. PreOrderTraverse(T->lchild);//访问左子树
  45. PreOrderTraverse(T->rchild);//访问右子树
  46. }
  47. void InOrderTraverse(BiTree T)
  48. {
  49. if (T == NULL)
  50. {
  51. return;
  52. }
  53. InOrderTraverse(T->lchild);//访问左子树
  54. printf("%c",T->data);//访问根结点
  55. InOrderTraverse(T->rchild);//访问右子树
  56. }
  57. void PostOrderTraverse(BiTree T)
  58. {
  59. if (T == NULL)
  60. {
  61. return;
  62. }
  63. PostOrderTraverse(T->lchild);//访问左子树
  64. PostOrderTraverse(T->rchild);//访问右子树
  65. printf("%c",T->data);//访问根结点
  66. }
  67. int main()
  68. {
  69. char *s1 = "ABCDEFG";
  70. char *s2 = "CBEDAFG";
  71. BiTree T = NULL;
  72. PostOrderTraverse(s1,s1+strlen(s1)-1, s2,s2+strlen(s2)-1,T);
  73. PreOrderTraverse(T);
  74. printf("\n");
  75. InOrderTraverse(T);
  76. printf("\n");
  77. PostOrderTraverse(T);
  78. printf("\n");
  79. return 0;
  80. }

文章来源: blog.csdn.net,作者:悦来客栈的老板,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/qq523176585/article/details/17268219

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。