首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >遍历avl树

遍历avl树
EN

Stack Overflow用户
提问于 2016-01-08 18:22:01
回答 1查看 939关注 0票数 0

我现在编写了一个AVL-tree,并编写了一个迭代器方法,以便按预定顺序遍历整个树。如果我处理'stack.empty()‘这行代码,却不知道为什么,我会得到一个NullPointer。4只眼睛确实比两只眼睛看得更清楚;)。提前感谢您的帮助。

代码:

代码语言:javascript
复制
@Override
public Iterator<E> iterator() {

    return new Iterator<E>(){
        Node start;
        Node current;
        //          int counter;
        Stack<Node> stack;
        //          int border = count(root);

        public void iterator() {

            stack = new Stack<Node>();
            current = start;
            stack.add(root);
        }

        @Override
        public boolean hasNext() {
            if(stack.empty()) return false;
            else return true;
        }

        @Override
        public E next() {
            if(!hasNext()){
                throw new NoSuchElementException();
            }
            Node n = stack.pop();
            if(n.left.value != null) stack.push(n.left);
            if(n.right.value != null) stack.push(n.right);

            return  n.value;            
        }

    };
}
EN

回答 1

Stack Overflow用户

发布于 2016-01-08 18:26:16

您的意思可能是n.left != null

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34674609

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档