<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    天地之間

    子曾經(jīng)曰過:"知之為知之,不知為不知!"

    java中LinkedList 集合類實現(xiàn)棧和隊列

    棧和隊列是兩種特殊的線性表,它們的邏輯結(jié)構(gòu)和線性表相同,只是其運算規(guī)則較線性表有更多的限制,故又稱它們?yōu)檫\算受限的線性表。

    LinkedList數(shù)據(jù)結(jié)構(gòu)是一種雙向的鏈?zhǔn)浇Y(jié)構(gòu),每一個對象除了數(shù)據(jù)本身外,還有兩個引用,分別指向前一個元素和后一個元素,和數(shù)組的順序存儲結(jié)構(gòu)(如:ArrayList)相比,插入和刪除比較方便,但速度會慢一些。

    棧的定義
    ???  (Stack)是限制僅在表的一端進(jìn)行插入和刪除運算的線性表。
      (1)通常稱插入、刪除的這一端為棧頂(Top),另一端稱為棧底(Bottom)。
      (2)當(dāng)表中沒有元素時稱為空棧
      (3)棧為后進(jìn)先出(Last In First Out)的線性表,簡稱為LIFO表
    ???  棧的修改是按后進(jìn)先出的原則進(jìn)行。每次刪除(退棧)的總是當(dāng)前棧中"最新"的元素,即最后插入(進(jìn)棧)的元素,而最先插入的是被放在棧的底部,要到最后才能刪除。

    實現(xiàn)代碼:
    package com.gc.list;
    import java.util.*;
    public class MyStack {

    ?private LinkedList ll=new LinkedList();
    ?
    ?public void push(Object o){
    ??ll.addFirst(o);
    ?}
    ?public Object pop(){
    ??return ll.removeFirst();
    ?}
    ?
    ?public Object peek(){
    ??return ll.getFirst();
    ?}
    ?
    ?public boolean empty(){
    ??return ll.isEmpty();
    ?}
    ?
    ?public static void main(String[] args){
    ??MyStack ms=new MyStack();
    ??ms.push("zhangsan");
    ??ms.push("lisi");
    ??ms.push("wangwu");
    ??
    ??System.out.println(ms.pop());
    ??System.out.println(ms.peek());
    ??System.out.println(ms.pop());
    ??System.out.println(ms.empty());
    ?}
    }


    隊列定義
    ???  隊列(Queue)是只允許在一端進(jìn)行插入,而在另一端進(jìn)行刪除的運算受限的線性表

      (1)允許刪除的一端稱為隊頭(Front)
      (2)允許插入的一端稱為隊尾(Rear)
      (3)當(dāng)隊列中沒有元素時稱為空隊列
      (4)隊列亦稱作先進(jìn)先出(First In First Out)的線性表,簡稱為FIFO表

    實現(xiàn)代碼:
    package com.gc.list;
    import java.util.*;
    public class MyQueue {

    ?private LinkedList ll=new LinkedList();
    ?public void put(Object o){
    ??ll.addLast(o);
    ?}
    ?//使用removeFirst()方法,返回隊列中第一個數(shù)據(jù),然后將它從隊列中刪除
    ?public Object get(){
    ??return ll.removeFirst();
    ?}
    ?
    ?public boolean empty(){
    ??return ll.isEmpty();
    ?}
    ?
    ?public static void main(String[] args){
    ??MyQueue mq=new MyQueue();
    ??mq.put("zhangsan");
    ??mq.put("lisi");
    ??mq.put("wangwu");
    ??
    ??System.out.println(mq.get());
    ??System.out.println(mq.get());
    ??System.out.println(mq.get());
    ??System.out.println(mq.empty());
    ??
    ?}
    }

    posted on 2007-02-25 14:30 xiaobailong 閱讀(958) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲AⅤ男人的天堂在线观看| 亚洲国产综合专区在线电影| 亚洲欧洲无码一区二区三区| 1000部拍拍拍18勿入免费凤凰福利| 亚洲AV无码久久精品蜜桃| a级毛片免费全部播放| 国产V亚洲V天堂无码久久久| 两个人看的www免费高清| 亚洲国产精品VA在线观看麻豆| a级在线免费观看| 久久精品国产亚洲av水果派| 亚洲免费在线观看视频| 亚洲1区1区3区4区产品乱码芒果| 中文字幕影片免费在线观看| 亚洲国产精品嫩草影院| www亚洲精品少妇裸乳一区二区| 一级做a爰性色毛片免费| 亚洲国产精品一区第二页| **aaaaa毛片免费| 亚洲精品精华液一区二区| 亚洲国产成人精品久久久国产成人一区二区三区综 | 亚洲三级高清免费| 在线免费观看国产视频| 一级成人毛片免费观看| 亚洲va在线va天堂va888www| 午夜性色一区二区三区免费不卡视频| 中日韩亚洲人成无码网站| 免费人成网站7777视频| 久久久国产精品福利免费| 亚洲精品福利你懂| 亚洲五月午夜免费在线视频| 久久国产免费一区| 亚洲国产精品ⅴa在线观看| 亚洲色自偷自拍另类小说| 国产免费的野战视频| 杨幂最新免费特级毛片| 亚洲天天做日日做天天看| 日韩精品视频免费在线观看| 两个人看的www免费视频| 亚洲xxxxxx| 亚洲精品乱码久久久久66|