当前位置:   article > 正文

【C++】面试101,按之字形顺序打印二叉树,二叉树的最大深度, 二叉树中和为某一值的路径(一),二叉搜索树与双向链表, 对称的二叉树_c++ 二叉树 层序反转打印

c++ 二叉树 层序反转打印

目录

1.按之字形顺序打印二叉树

 2.二叉树的最大深度

3. 二叉树中和为某一值的路径(一)

4.二叉搜索树与双向链表

 5.  对称的二叉树


1.按之字形顺序打印二叉树

其实就是二叉树层序遍历,只不过奇数层需要反转(用reverse)

层序遍历昨天讲过的层序以及前中后序

  1. class Solution {
  2. public:
  3. void level(vector<vector<int>>& vv, TreeNode* root, int depth)
  4. {
  5. if (!root) return;
  6. if (vv.size() > depth)
  7. vv[depth].push_back(root->val);
  8. else
  9. {
  10. vector<int> v;
  11. v.push_back(root->val);
  12. vv.push_back(v);
  13. }
  14. level(vv, root->left, depth + 1);
  15. level(vv, root->right, depth + 1);
  16. }
  17. vector<vector<int> > Print(TreeNode* pRoot) {
  18. vector<vector<int>> vv; //创建二维数组
  19. level(vv, pRoot, 0); //层序
  20. for (int i = 0; i < vv.size(); i++)
  21. {
  22. if (i % 2) //奇数层逆置
  23. reverse(vv[i].begin(), vv[i].end());
  24. }
  25. return vv;
  26. }
  27. };

 2.二叉树的最大深度

二叉树的最大深度=左子树的最大深度+右子树的最大深度+1(根)

当然空树直接返回0

  1. int maxDepth(TreeNode* root) {
  2. // write code here
  3. if(!root) return 0;
  4. int a1=maxDepth(root->left);
  5. int a2=maxDepth(root->right);
  6. return max(a1,a2)+1;
  7. }

3. 二叉树中和为某一值的路径(一)

只要一条路径符合就可以每次走过一条路径上的第一个非空节点,我们就从sum中减去节点值

最后当节点为空,返回false(说明走到空之后sum还没有被减空),如果左右都为空(走到当前路径最后一个节点上),判断sum和val是否相等

  1. bool hasPathSum(TreeNode* root, int sum) {
  2. // write code here
  3. if(!root ) return false;
  4. if(!root->left && !root->right) return root->val==sum;
  5. return hasPathSum(root->left, sum-root->val)||hasPathSum(root->right, sum-root->val);
  6. }

4.二叉搜索树与双向链表

这个题可以看成中序遍历的变式

找左,一直往左走,根的时候加上双向链表的链接,并且链接一个删除一个栈内节点,然后走左

 

  1. TreeNode* Convert(TreeNode* pRootOfTree)
  2. {
  3. if (!pRootOfTree) return nullptr; //空树,直接返回
  4. stack<TreeNode*> s; //栈
  5. TreeNode* head = nullptr, * pre = nullptr; //head是双向链表的头,pre是链接位置的前一个
  6. bool First = true; //判断是不是链表第一个节点
  7. while (pRootOfTree || !s.empty()) //栈不为空说明这个路径还没有走完
  8. {
  9. while (pRootOfTree) //一直到最左侧的节点(找最小)
  10. {
  11. s.push(pRootOfTree); //把经过的每一个节点 入栈
  12. pRootOfTree = pRootOfTree->left; //往左走
  13. }
  14. pRootOfTree = s.top(); //由于刚才结束条件是空,所以栈顶元素就是最小节点
  15. s.pop(); //删除栈顶,这样下次找到次小的
  16. if (First) //判断是不是链表头
  17. {
  18. head = pRootOfTree;//当前整个树最小节点就是链表头
  19. pre = pRootOfTree;
  20. First = false;
  21. }
  22. else {
  23. pre->right = pRootOfTree;//不是链表头就正常连接
  24. //pre pRootOfTree
  25. pRootOfTree->left = pre;
  26. pre = pRootOfTree; //pre后移
  27. }
  28. pRootOfTree = pRootOfTree->right; //右走
  29. }
  30. return head;
  31. }

当然中序可以写成递归

 

  1. TreeNode* Convert(TreeNode* pRootOfTree) {
  2. if (!pRootOfTree) return nullptr;
  3. Convert(pRootOfTree->left);
  4. if (!pre)
  5. {
  6. head = pRootOfTree;
  7. pre = pRootOfTree;
  8. }
  9. else {
  10. pre->right = pRootOfTree;
  11. pRootOfTree->left = pre;
  12. pre = pRootOfTree;
  13. }
  14. Convert(pRootOfTree->right);
  15. return head;
  16. }

 5.  对称的二叉树

分别比较左子树和右子树的每个节点

  1. bool _isSymmetrical(TreeNode* p1, TreeNode* p2) {
  2. if (!p1 && !p2) return true; //两个节点都是空,true
  3. if ((p1 && !p2) || (!p1 && p2) || (p1->val != p2->val)) return false;//一个空另一个不空或者两个节点值不一样都false
  4. return _isSymmetrical(p1->left, p2->right) && //看镜像而不是看对称
  5. _isSymmetrical(p1->right, p2->left);
  6. }
  7. bool isSymmetrical(TreeNode* pRoot) {
  8. if (!pRoot) return true; //空树自然镜像
  9. return _isSymmetrical(pRoot->left, pRoot->right);
  10. }

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/木道寻08/article/detail/837157
推荐阅读
相关标签
  

闽ICP备14008679号