一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 276|回复: 1
收起左侧

[Leetcode] Binary Search Tree Iterator

[复制链接] |试试Instant~ |关注本帖
qiuxuxing007 发表于 2015-7-30 13:18:35 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
感觉这题 很经典,当然了 代码 参考了 网上 大神们的答案 但自己 做了 略微的改进 ,欢迎讨论,thank you.

public class BSTIterator {
    int index=0;
    ArrayList<TreeNode> res = new ArrayList<TreeNode>();
    public BSTIterator(TreeNode root) {
    helper(root, res);
    }

     public void helper (TreeNode root, ArrayList<TreeNode> res) {
         if (root == null) {
            return;
        }
         //中序遍历就是把bst 按从大到小输出
         helper(root.left, res);
         res.add(root);
         helper(root.right, res);
     }

    /** @return whether we have a next smallest number */
    public boolean hasNext() {
     if (index < res.size()) {
             return true;
         }
         return false;
    }

    /** @return the next smallest number */
    public int next() {
     int a = res.get(index).val;
       index++;
     return a;
    }
}

zhuli19901106 发表于 2015-7-30 21:31:03 | 显示全部楼层
本帖最后由 zhuli19901106 于 2015-7-30 21:40 编辑

这种是O(N)预处理时间,O(1)查询时间,O(N)全局空间的解法。
这题还有O(H)时间,O(1)空间的做法,楼主再琢磨一下?其中H代表树的高度。
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-3 04:03

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表