美文网首页
单向链表的reverse实现(三)

单向链表的reverse实现(三)

作者: 王刚_768f | 来源:发表于2018-04-11 14:41 被阅读0次

上一篇的MyLinkedList实现了一个双向链表,如何对单向链表实现reverse操作呢?下面是实现代码,基本思路和双向链表一样:遍历每个节点元素,改变节点的链接。但是由于单向链表每个节点只拥有一个后继链接,所以每次操作当前遍历的节点对象时需要额外的两个引用pc和pn,分别指向已经反转过的链表和尚未进行反转操作的链表,直到pn==null退出循环。

public class MySingleLinkedList<E> {
    private int size;
    private SingleNode<E> first;
    private SingleNode<E> last;

    public SingleNode<E> getLast() {
        return last;
    }

    public void setLast(SingleNode<E> last) {
        this.last = last;
    }

    public int getSize() {
        return size;
    }

    public void setSize(int size) {
        this.size = size;
    }

    public SingleNode<E> getFirst() {
        return first;
    }

    public void setFirst(SingleNode<E> first) {
        this.first = first;
    }
    //add方法
    public boolean add(E item){
        if(size<0 || size>=Integer.MAX_VALUE){
            return false;
        }
        SingleNode<E> node= new SingleNode<E>(item,null);
        if(size==0){
           first=node;
           last=node;
           size++;
        } else{
            last.setNext(node);
            last=node;
            size++;
        }
        return true;
    }
}
public class SingleNode<E> {
    E item;
    SingleNode<E> next;

    public SingleNode(E item, SingleNode<E> next) {
        this.item = item;
        this.next = next;
    }

    //省略get,set方法
}

public class MySingleLinkedListReverse<E> {
    public MySingleLinkedList<E> reverse(MySingleLinkedList<E> list){
        if(list ==null || list.getSize()<2){
            return list;
        }
        SingleNode<E> pc=list.getFirst();
        SingleNode<E> pp=null;
        SingleNode<E> pn=pc.getNext();
        while(pn!=null){
            pc.setNext(pp);
            pp=pc;
            pc=pn;
            pn=pn.getNext();
        }
        pc.setNext(pp);
        list.setLast(list.getFirst());
        list.setFirst(pc);
        return list;
    }
}

测试用例和运行结果如下

public class MySingleLinkedListTest {
    public static void main(String[] args) {
        MySingleLinkedList<Integer> list=new MySingleLinkedList<Integer>();
        for(int i=0;i<40000;i++){
            list.add(i);
        }
        Long startTime=System.currentTimeMillis();
        System.out.println("开始时间="+startTime.longValue());
       MySingleLinkedList<Integer> rList=new MySingleLinkedListReverse<Integer>().reverse(list);
       Long endTime=System.currentTimeMillis();
        System.out.println("结束时间="+endTime.longValue());
        System.out.println("单向链表,复用node 4万条记录耗时="+(endTime-startTime));
    }
}
图片.png

相关文章

网友评论

      本文标题:单向链表的reverse实现(三)

      本文链接:https://www.haomeiwen.com/subject/ahaahftx.html