博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[LeetCode] Binary Tree Postorder Traversal
阅读量:6291 次
发布时间:2019-06-22

本文共 2965 字,大约阅读时间需要 9 分钟。

This is a fundamental and yet classic problem. I share my three solutions here:

  1. Iterative solution using stack --- O(n) time and O(n) space;
  2. Recursive solution --- O(n) time and O(n) space (considering the costs of call stack);
  3. Morris traversal --- O(n) time and O(1) space!!!

Iterative solution using stack:

1 vector
postorderTraversal(TreeNode* root) { 2 vector
nodes; 3 stack
toVisit; 4 TreeNode* curNode = root; 5 TreeNode* lastNode = NULL; 6 while (curNode || !toVisit.empty()) { 7 if (curNode) { 8 toVisit.push(curNode); 9 curNode = curNode -> left;10 }11 else {12 TreeNode* topNode = toVisit.top();13 if (topNode -> right && lastNode != topNode -> right)14 curNode = topNode -> right;15 else {16 nodes.push_back(topNode -> val);17 lastNode = topNode;18 toVisit.pop();19 }20 }21 }22 return nodes;23 }

Recursive solution:

1 void postorder(TreeNode* root, vector
& nodes) { 2 if (!root) return; 3 postorder(root -> left, nodes); 4 postorder(root -> right, nodes); 5 nodes.push_back(root -> val); 6 } 7 vector
postorderTraversal(TreeNode* root) { 8 vector
nodes; 9 postorder(root, nodes);10 return nodes;11 }

Morris traversal:

1 void reverseNodes(TreeNode* start, TreeNode* end) { 2     if (start == end) return; 3     TreeNode* x = start; 4     TreeNode* y = start -> right; 5     TreeNode* z; 6     while (x != end) { 7         z = y -> right; 8         y -> right = x; 9         x = y;10         y = z;11     }12 }13 void reverseAddNodes(TreeNode* start, TreeNode* end, vector
& nodes) {14 reverseNodes(start, end);15 TreeNode* node = end;16 while (true) {17 nodes.push_back(node -> val);18 if (node == start) break;19 node = node -> right;20 }21 reverseNodes(end, start);22 }23 vector
postorderTraversal(TreeNode* root) {24 vector
nodes;25 TreeNode* dump = new TreeNode(0);26 dump -> left = root;27 TreeNode* curNode = dump;28 while (curNode) {29 if (curNode -> left) {30 TreeNode* predecessor = curNode -> left;31 while (predecessor -> right && predecessor -> right != curNode)32 predecessor = predecessor -> right;33 if (!(predecessor -> right)) {34 predecessor -> right = curNode;35 curNode = curNode -> left;36 }37 else {38 reverseAddNodes(curNode -> left, predecessor, nodes);39 predecessor -> right = NULL;40 curNode = curNode -> right;41 }42 }43 else curNode = curNode -> right;44 }45 return nodes;46 }

 

转载地址:http://ftuta.baihongyu.com/

你可能感兴趣的文章
Mellanox公司计划利用系统芯片提升存储产品速度
查看>>
白帽子守护网络安全,高薪酬成大学生就业首选!
查看>>
ARM想将芯片装进人类大脑 降低能耗是一大挑战
查看>>
Oracle数据库的备份方法
查看>>
Selenium 自动登录考勤系统
查看>>
关于如何以编程的方式执行TestNG
查看>>
智能照明造福千家万户 家居智能不再是梦
查看>>
物联网如何跳出“看起来很美”?
查看>>
浅谈MySQL 数据库性能优化
查看>>
《UNIX/Linux 系统管理技术手册(第四版)》——1.10 其他的权威文档
查看>>
灵动空间 创享生活
查看>>
《UNIX网络编程 卷1:套接字联网API(第3版)》——8.6 UDP回射客户程序:dg_cli函数...
查看>>
不要将时间浪费到编写完美代码上
查看>>
《算法基础:打开算法之门》一3.4 归并排序
查看>>
高德开放平台开放源代码 鼓励开发者创新
查看>>
《高并发Oracle数据库系统的架构与设计》一2.5 索引维护
查看>>
Firefox 是 Pwn2own 2014 上攻陷次数最多的浏览器
查看>>
阿里感悟(十八)- 应届生Review
查看>>
话说模式匹配(5) for表达式中的模式匹配
查看>>
《锋利的SQL(第2版)》——1.7 常用函数
查看>>