灿夏 2018-07-14 04:48 采纳率: 100%
浏览 2769
已采纳

Java该怎么遍历链表数据结构

贴上代码, 我想问一下嵌套类ReverseArrayIterator中的next() 方法该怎样写,才能完成链表

 /**
 * 下压栈链表实现
 *
 * @author maji
 * @date 2018-7-14
 */
public class Stack<Item> implements Iterable<Item> {
    private Node first;
    private int N;

    private class Node {
        Item item;
        Node next;
    }

    public boolean isEmpty() {
        return first == null;
    }

    public int size() {
        return N;
    }

    public void push(Item item) {
        Node oldFirst = first;
        first = new Node();
        first.item = item;
        first.next = oldFirst;
        N++;
    }

    public Item pop() {
        Item item = first.item;
        first = first.next;
        N--;
        return item;
    }

    @Override
    public Iterator<Item> iterator() {
        return new ReverseArrayIterator();
    }

    private class ReverseArrayIterator implements Iterator<Item> {
        private int i = N;

        @Override
        public boolean hasNext() {
            return i > 0;
        }

        @Override
        public Item next() {

                for (Node x = first; x != null; x = x.next) {
                    return x.item;

                }


        }

        @Override
        public void remove() {
        }

    }

}

  • 写回答

3条回答 默认 最新

  • threenewbee 2018-07-14 05:05
    关注
     import java.util.*;
    
    class Untitled {    
    
        class Stack<Item> implements Iterable<Item> {
            private Node first;
            private int N;
    
            private class Node {
                Item item;
                Node next;
            }
    
            public boolean isEmpty() {
                return first == null;
            }
    
            public int size() {
                return N;
            }
    
            public void push(Item item) {
                Node oldFirst = first;
                first = new Node();
                first.item = item;
                first.next = oldFirst;
                N++;
            }
    
            public Item pop() {
                Item item = first.item;
                first = first.next;
                N--;
                return item;
            }
    
            @Override
            public Iterator<Item> iterator() {
                return new ReverseArrayIterator();
            }
    
            private class ReverseArrayIterator implements Iterator<Item> {
                private int i = N;
    
                @Override
                public boolean hasNext() {
                    return i > 0;
                }
    
                @Override
                public Item next() {
                    i--;
                    return pop();
                }
    
                @Override
                public void remove() {
                }
    
            }
    
        }
    
        public void foo()
        {
            Untitled.Stack<Integer> list = new Untitled.Stack<Integer>();
            list.push(new Integer(1));
            list.push(new Integer(2));
            list.push(new Integer(3));
            for (int i : list)
                System.out.println(i);
        }
    
        public static void main(String[] args) {
            new Untitled().foo();
        }
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 delta降尺度计算的一些细节,有偿
  • ¥15 Arduino红外遥控代码有问题
  • ¥15 数值计算离散正交多项式
  • ¥30 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序