数据结构 中序后序求前序

举报
悦来客栈的老板 发表于 2020/12/28 23:33:25 2020/12/28
【摘要】 #include <stdio.h>#include <stdlib.h>#include <string.h> void preOrderTraverse(const char *inStart, const char *inEnd,const char *postStart, const char *postEnd){ char roo...

  
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4. void preOrderTraverse(const char *inStart, const char *inEnd,const char *postStart, const char *postEnd)
  5. {
  6. char root = *postEnd;
  7. printf("%c",root);
  8. int len = postEnd - postStart,i = 0;
  9. for(;*(inStart+i) != root && i<=len; i++); //查找根结点在中序的位置
  10. if (i != 0)
  11. {//如果不是第一个,说明其含有左子树
  12. preOrderTraverse(inStart, inStart+i-1,postStart, postStart+i-1);
  13. }
  14. if (i != len)
  15. {//如果不是最后一个,说明其含有右子树
  16. preOrderTraverse(inStart+i+1, inEnd,postStart+i, postEnd-1);
  17. }
  18. }
  19. int main()
  20. {
  21. char *s1 = "ABCDEFG";
  22. char *s2 = "BDCAFGE";
  23. preOrderTraverse(s1,s1+strlen(s1)-1, s2,s2+strlen(s2)-1);
  24. printf("\n");
  25. return 0;
  26. }

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

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

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

评论(0

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

全部回复

上滑加载中

设置昵称

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

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

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