码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 2014软专算法题T1


    如果要对二叉树进行自下而上,自右向左的层次遍历,请给出遍历算法。

    解题思路:ggt

    1.采用层次遍历,初始化一个空队列和空栈

    2.每次出队时将该元素入栈,直至层次遍历结束

    3.不断将栈顶元素出栈,同时对其访问,直至栈空

     ps:偷懒将层次遍历的序列存入数组中,在将数组中的data值逆序输出,即可得到反向层次遍历的序列

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. //string qx="12400500300";//完全二叉树测试数据
    6. //string zx="04020501030";
    7. string qx="123" ;//非完全二叉树测试数据
    8. string zx="321";
    9. const int MaxSize=100;
    10. typedef struct Tree//二叉树结构定义
    11. {
    12. int data;
    13. Tree *left;
    14. Tree *right;
    15. } *BiTree;
    16. BiTree build(string qx,string zx)//建树
    17. {
    18. if(qx.size()==0)return NULL;
    19. Tree *root=(Tree *)malloc(sizeof(Tree));
    20. root->data=qx[0]-'0';
    21. int pos=zx.find(qx[0]);
    22. root->left=build(qx.substr(1,pos),zx.substr(0,pos));
    23. root->right=build(qx.substr(pos+1),zx.substr(pos+1));
    24. return root;
    25. }
    26. typedef struct LinkNode//队列结点
    27. {
    28. BiTree data;
    29. LinkNode *next;
    30. }LinkNode,*Link;
    31. typedef struct Queue//链队列
    32. {
    33. LinkNode *front;
    34. LinkNode *rear;
    35. }*queue;
    36. void InitQueue(Queue &Q)
    37. {
    38. Q.front=Q.rear=(LinkNode*)malloc(sizeof(LinkNode));
    39. Q.front->next=NULL;
    40. }
    41. bool isEmpty(Queue Q)
    42. {
    43. if(Q.front==Q.rear) return true;
    44. else return false;
    45. }
    46. void EnQueue(Queue &Q,BiTree x)
    47. {
    48. LinkNode *p=(LinkNode*)malloc(sizeof(LinkNode));
    49. p->data=x;
    50. p->next=Q.rear->next;
    51. Q.rear->next=p;
    52. Q.rear=p;
    53. }
    54. bool DeQueue(Queue &Q,BiTree &x)
    55. {
    56. if(Q.front==Q.rear) return false;
    57. LinkNode *p=Q.front->next;
    58. x=p->data;
    59. Q.front->next=p->next;
    60. if(Q.rear==p) Q.rear=Q.front;
    61. return true;
    62. }
    63. void LevelOrder(BiTree T)//层次遍历
    64. {
    65. int a[10];
    66. int i=0;
    67. BiTree x;
    68. Queue Q;
    69. InitQueue(Q);
    70. BiTree p=T;
    71. EnQueue(Q,p);
    72. while(!isEmpty(Q))
    73. {
    74. DeQueue(Q,x);
    75. a[i++]=x->data;//将层次遍历得到的序列存入数组中
    76. if(x->left!=NULL)
    77. EnQueue(Q,x->left);
    78. if(x->right!=NULL)
    79. EnQueue(Q,x->right);
    80. }
    81. for(int j=i-1;j>=0;j--)//将数组中的data值逆序输出
    82. {
    83. printf("%d ",a[j]);
    84. }
    85. }
    86. int main()
    87. {
    88. BiTree T=build(qx,zx);
    89. LevelOrder(T);
    90. }

  • 相关阅读:
    Service & Endpoint
    TCP协议_三次握手与四次挥手
    上海计算机学会 2024年4月月赛 丙组T1 最大公约数
    DVWA靶场&Brute Force 暴力破解&审计通关教程
    Windows下,用python代码编译打包成可执行文件,并设置自启动步骤
    C#冒泡排序算法
    java 异常基本概念,计算机默认处理,书写捕获处理异常
    m基于matlab的OQPSK载波同步通信系统仿真,载波同步采用costas环
    Android 使用FFmpeg3.3.9基于命令实现视频压缩
    数字化门店| 美甲美睫店管理系统| 小程序教程
  • 原文地址:https://blog.csdn.net/UncleJokerly/article/details/127970839
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号