LinkedList的reverse實(shí)現(xiàn)(二)

上篇實(shí)現(xiàn)LinkedList的reverse完全依賴的是源碼的API,但是這種實(shí)現(xiàn)的問(wèn)題在于每次訪問(wèn)原list的元素后都new了一個(gè)node對(duì)象崇堰,這會(huì)導(dǎo)致更多的內(nèi)存被占用升熊。下面考慮復(fù)用原始list的node來(lái)實(shí)現(xiàn)reverse俄烁。

要復(fù)用node節(jié)點(diǎn)對(duì)象需要重新實(shí)現(xiàn)一個(gè)LinkedList,因?yàn)樵创a中的LinkedList沒(méi)有暴露操縱node成員變量的方法。下面是一個(gè)實(shí)現(xiàn)的List接口的MyLinkedList

public  class MyLinkedList<E> implements List<E> {
    private int size;
    private Node<E> first;
    private Node<E> last;
    public int getSize() {
        return size;
    }
    public void setSize(int size) {
        this.size = size;
    }
    public Node<E> getFirst() {
        return first;
    }
    public void setFirst(Node<E> first) {
        this.first = first;
    }
    public Node<E> getLast() {
        return last;
    }
    public void setLast(Node<E> last) {
        this.last = last;
    }
 @Override
    public boolean add(E e) {
        if(size!=0){
            Node<E> node=new Node<E>(e,last,null);
            last.setNext(node);
            last=node;
            size++;
            return true;
        }else{
            Node<E> node=new Node<E>(e,null,null);
            last=node;
            first=node;
            size++;
            return true;
        }
    }
public E removeFirst(){
        if(size==0){
            return null;
        }
        E item=first.getItem();
        size--;
        first=first.getNext();
        if(first==null){
            last=null;
        }
        return item;
    }
.........

由于要在MyLinkedList對(duì)象外操作node節(jié)點(diǎn)對(duì)象级野,故:(1)需要提供node成員變量的get,set方法页屠,(2)Node<E>不能嵌套定義在MyLinedList內(nèi)部,下面是我定義的Node<E>類

public class Node<E> {
    private E item;
    private Node<E> next;
    private Node<E> pre;
    public Node(E item,Node<E> pre,Node<E> next){
        this.item=item;
        this.pre=pre;
        this.next=next;
    }
    public Node<E> exchangeDirection(Node<E>  node){
        Node<E> temp=node.getNext();
        node.setNext(node.getPre());
        node.setPre(temp);
        return node;
    }
    //省略get,set方法

用例測(cè)試代碼如下

public class MyLinkedListTest {
    public static void main(String[] args) {
        MyLinkedList<Integer> list=new MyLinkedList<Integer>();
        for(int i=0;i<40000;i++){
            list.add(i);
        }
        Long startTime=System.currentTimeMillis();
        System.out.println("開(kāi)始時(shí)間="+startTime.longValue());
        MyLinkedList<Integer> rList=new MyLinkedListReverse<Integer>().reverse(list);
        Long endTime=System.currentTimeMillis();
        System.out.println("結(jié)束時(shí)間="+endTime);
        System.out.println("復(fù)用node 4萬(wàn)耗時(shí)="+(endTime-startTime));
        int size=rList.size();
        for(int i=0;i<size;i++){
            System.out.println(rList.removeFirst().intValue());
        }
    }
}

運(yùn)行結(jié)果如下:


圖片.png

之前用new node的用例測(cè)試代碼和實(shí)驗(yàn)結(jié)果如下

public class LinkedListTest {
    public static void main(String[] args) {
        LinkedList<Integer> list=new LinkedList<Integer>();
        for(int i=0;i<40000;i++){
            list.add(i);
        }
        System.out.println("原始的LinkedList的size="+list.size());
        Long startTime=System.currentTimeMillis();
        System.out.println("開(kāi)始時(shí)間="+startTime.longValue());
        List<Integer> reversedList= new LinkedListReverse<Integer>().reverse(list);
        Long endTime=System.currentTimeMillis();
        System.out.println("結(jié)束時(shí)間="+endTime.longValue());
        System.out.println("通過(guò)new node實(shí)現(xiàn)4萬(wàn)條反轉(zhuǎn)時(shí)間="+(endTime-startTime));
        for(Integer i: reversedList){
            System.out.println(i.intValue());
        }
    }
}
public class LinkedListReverse <E> {
    public LinkedList<E> reverse(LinkedList<E> list){
        if(list.getFirst()==null){
            return null;
        }
        LinkedList<E> reversedList=new LinkedList<E>();
        E item=null;
        int n=list.size();
        for(int i=0;i<n;i++){
            reversedList.add(list.removeLast());
        }
        return reversedList;
    }
}

圖片.png

從運(yùn)行結(jié)果上看蓖柔,復(fù)用node的實(shí)現(xiàn)效率更高辰企,這應(yīng)該是節(jié)省了new對(duì)象的開(kāi)銷(xiāo)得到的好處。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末况鸣,一起剝皮案震驚了整個(gè)濱河市牢贸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌镐捧,老刑警劉巖潜索,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異懂酱,居然都是意外死亡竹习,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)列牺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)整陌,“玉大人,你說(shuō)我怎么就攤上這事瞎领∶诒瑁” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵九默,是天一觀的道長(zhǎng)震放。 經(jīng)常有香客問(wèn)我,道長(zhǎng)荤西,這世上最難降的妖魔是什么澜搅? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任伍俘,我火速辦了婚禮,結(jié)果婚禮上勉躺,老公的妹妹穿的比我還像新娘癌瘾。我一直安慰自己,他們只是感情好饵溅,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布妨退。 她就那樣靜靜地躺著,像睡著了一般蜕企。 火紅的嫁衣襯著肌膚如雪咬荷。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,816評(píng)論 1 290
  • 那天轻掩,我揣著相機(jī)與錄音幸乒,去河邊找鬼。 笑死唇牧,一個(gè)胖子當(dāng)著我的面吹牛罕扎,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播丐重,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼腔召,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了扮惦?” 一聲冷哼從身側(cè)響起臀蛛,我...
    開(kāi)封第一講書(shū)人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎崖蜜,沒(méi)想到半個(gè)月后浊仆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡豫领,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年氧卧,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片氏堤。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖搏明,靈堂內(nèi)的尸體忽然破棺而出鼠锈,到底是詐尸還是另有隱情,我是刑警寧澤星著,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布购笆,位于F島的核電站,受9級(jí)特大地震影響虚循,放射性物質(zhì)發(fā)生泄漏同欠。R本人自食惡果不足惜样傍,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望铺遂。 院中可真熱鬧衫哥,春花似錦、人聲如沸襟锐。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)粮坞。三九已至蚊荣,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間莫杈,已是汗流浹背互例。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留筝闹,地道東北人媳叨。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像丁存,于是被迫代替她去往敵國(guó)和親肩杈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容