173. Binary Search Tree Iterator
来源:互联网 发布:淘宝闲置物品交易规则 编辑:程序博客网 时间:2024/06/05 04:47
Implement an iterator over a binary search tree (BST). Your iterator will be initialized with the root node of a BST.
Calling next()
will return the next smallest number in the BST.
Note: next()
and hasNext()
should run in average O(1) time and uses O(h) memory, where h is the height of the tree.
借助栈来实现,栈中保存输出顺序
/** * Definition for binary tree * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode(int x) : val(x), left(NULL), right(NULL) {} * }; */class BSTIterator {public: stack<TreeNode*> st; BSTIterator(TreeNode *root) { find_left(root); } /** @return whether we have a next smallest number */ bool hasNext() { return !st.empty(); } /** @return the next smallest number */ int next() { TreeNode* result = st.top(); st.pop(); if(result->right) find_left(result->right); return result->val; }private: void find_left(TreeNode* node) { while(node){ st.push(node); node = node->left; } }};/** * Your BSTIterator will be called like this: * BSTIterator i = BSTIterator(root); * while (i.hasNext()) cout << i.next(); */
0 0
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator**
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 173. Binary Search Tree Iterator
- 网易新闻客户端iOS版本中新闻详情页(UIWebView)技术实现的分析探讨
- ACM解题总结——HihoCoder1299
- androd 屏幕分辨率对照表
- 关于ActionBar中setDisplayHomeAsUpEnabled(true)等方法的问题
- 调用门详解
- 173. Binary Search Tree Iterator
- spring统一管理异常和访问日志
- C++的头文件和实现文件分别写什么
- Java基本数据类型
- HDU 2608 0 or 1(数学推导)
- 内联函数
- 千奇百怪面试题
- LeetCode Reverse Words in a String
- Petya and Countryside<水题>