非递归实现二叉树先序、中序、后序和层序遍历

清疚 2022-12-29 04:54 220阅读 0赞

文章目录

      • 用非递归的方式实现二叉树的先序遍历
      • 用非递归的方式实现二叉树的中序遍历:
      • 用非递归的方式实现二叉树的后序遍历:
      • 用非递归的方式实现二叉树的层次遍历:

用递归方式实现二叉树先序、中序和后序遍历很简单。
用递归方法解决的问题都能用非递归的方法实现。递归就是利用函数栈来保存信息,如果用自己申请的数据结构来代替函数栈,也可以实现相同的功能。

全C++实现

用非递归的方式实现二叉树的先序遍历

1、申请一个栈stack,然后将头节点压入stack中。

2、从stack中弹出栈顶节点,打印,再将其右孩子节点(不为空的话)先压入stack中,最后将其左孩子节点(不为空的话)压入stack中。

3、不断重复步骤2,直到stack为空,全部过程结束。

  1. /**
  2. * 定义树节点
  3. * struct TreeNode {
  4. * int data;
  5. * TreeNode* left;
  6. * TreeNode* right;
  7. * };
  8. */
  9. void prev_iterate(TreeNode* root) {
  10. stack<TreeNode*> st; //申请栈存放树节点的指针
  11. if (root != NULL) {
  12. st.push(root);
  13. while (!st.empty()) {
  14. TreeNode* now = st.top();
  15. st.pop();
  16. printf("%d ", now->data); //打印树节点的数据,也可以用个数组把它存下来
  17. if (now->right != NULL) {
  18. st.push(now->right);
  19. }
  20. if (now->left != NULL) {
  21. st.push(now->left);
  22. }
  23. }
  24. }
  25. }

用非递归的方式实现二叉树的中序遍历:

1、申请一个栈stack,初始时令cur=root

2、先把cur压入栈中,依次把左边界压入栈中,即不停的令cur=cur->left,重复步骤2

3、不断重复2,直到为null,从stack中弹出一个节点,记为node,打印node的值,并令cur=node->right,重复步骤2

4、当stack为空且cur为空时,整个过程停止。

  1. /**
  2. * 定义树节点
  3. * struct TreeNode {
  4. * int data;
  5. * TreeNode* left;
  6. * TreeNode* right;
  7. * };
  8. */
  9. void mid_itertor(TreeNode* root) {
  10. stack<TreeNode*> st; //申请栈存放树节点的指针
  11. TreeNode* cur = root;
  12. while (cur != NULL && !st.empty()) {
  13. while(cur != NULL) {
  14. st.push(cur);
  15. cur = cur->left;
  16. }
  17. if (!st.empty()){
  18. cur = st.top();
  19. st.pop();
  20. printf("%d ", cur->data); //打印树节点的数据,也可以用个数组把它存下来
  21. cur = cur->right;
  22. }
  23. }
  24. }

用非递归的方式实现二叉树的后序遍历:

用非递归的方式实现后序遍历有点麻烦。

1、申请一个栈s1,然后将头节点压入栈s1中。

2、从s1中弹出的节点记为cur,然后依次将cur的左孩子节点和右孩子节点压入s1中。

3、在整个过程中,每一个从s1中弹出的节点都放进s2中。

4、不断重复步骤2和步骤3,直到s1为空,过程停止。

5、从s2中依次弹出节点并打印,打印的顺序就是后序遍历的顺序。

  1. /**
  2. * 定义树节点
  3. * struct TreeNode {
  4. * int data;
  5. * TreeNode* left;
  6. * TreeNode* right;
  7. * };
  8. */
  9. void next_itertor(TreeNode* root) {
  10. stack<TreeNode*> s1, s2;
  11. TreeNode* cur = root;
  12. if (root != NULL) {
  13. s1.push(cur);
  14. while (!s1.empty()) {
  15. cur = s1.top();
  16. s1.pop();
  17. s2.push(cur);
  18. if (cur->left != NULL) {
  19. s1.push(cur->left);
  20. }
  21. if (cur->right != NULL) {
  22. s1.push(cur->right);
  23. }
  24. }
  25. }
  26. while (!s2.empty()) {
  27. printf("%d ", s2.top()->data);
  28. s2.pop();
  29. }
  30. putchar(10);
  31. }

用非递归的方式实现二叉树的层次遍历:

从二叉树的第一层(根节点)开始,从上至下逐层遍历,在每一层中又按照从左到右的顺序对结点逐个遍历。我们可以看出如果某个结点比同一层的先遍历,其孩子也将比其同层的孩子结点先遍历,这种先进先出的方式,不就是队列这种数据结构吗?

  1. /**
  2. * 定义树节点
  3. * struct TreeNode {
  4. * int data;
  5. * TreeNode* left;
  6. * TreeNode* right;
  7. * };
  8. */
  9. void level_iterate(TreeNode* root){
  10. queue<TreeNode*> que;
  11. que.push(root);
  12. while (!que.empty()) {
  13. TreeNode* cur = que.front();
  14. que.pop();
  15. printf("%d ", cur->data);
  16. if (cur->left != NULL) {
  17. que.push(cur->left);
  18. }
  19. if (cur->right != NULL) {
  20. que.push(cur->right);
  21. }
  22. }
  23. }

发表评论

表情:
评论列表 (有 0 条评论,220人围观)

还没有评论,来说两句吧...

相关阅读