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

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

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

    love fish大鵬一曰同風(fēng)起,扶搖直上九萬里

    常用鏈接

    統(tǒng)計(jì)

    積分與排名

    friends

    link

    最新評(píng)論

    java中LinkedList 集合類實(shí)現(xiàn)棧和隊(duì)列(轉(zhuǎn))

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

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

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

    實(shí)現(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());
    ?}
    }


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

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

    實(shí)現(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()方法,返回隊(duì)列中第一個(gè)數(shù)據(jù),然后將它從隊(duì)列中刪除
    ?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-26 09:07 liaojiyong 閱讀(1076) 評(píng)論(0)  編輯  收藏 所屬分類: Java

    主站蜘蛛池模板: 免费黄色福利视频| 国产三级免费观看| 在线观看人成视频免费| 亚洲va中文字幕无码| 亚洲人成在线影院| 国产精品亚洲AV三区| 一级毛片不卡片免费观看| 四虎在线视频免费观看| 亚洲中文字幕久久久一区| 国产成人AV免费观看| 国产aa免费视频| 黄色一级视频免费观看| 免费a级毛片高清视频不卡 | 二个人看的www免费视频| AV免费网址在线观看| 亚洲色大成网站WWW国产| 成年轻人网站色免费看| 自怕偷自怕亚洲精品| 国产精品免费在线播放| 国产精品免费看香蕉| 国产精品亚洲片夜色在线 | 精品亚洲永久免费精品| 免费人妻无码不卡中文字幕18禁| 亚洲成人一级电影| 国内精品免费在线观看| 亚洲国产综合专区电影在线| 国产91色综合久久免费| 一本色道久久88—综合亚洲精品| 国产精品免费看香蕉| 任你躁在线精品免费| 亚洲欧洲日产专区| 国产大片51精品免费观看| 久久久精品视频免费观看 | 成年性午夜免费视频网站不卡| 亚洲国产欧洲综合997久久| 永久免费av无码网站韩国毛片| 亚洲欧洲国产视频| 青青青青青青久久久免费观看| 亚洲成A人片在线播放器| 午夜国产精品免费观看| 亚洲精品亚洲人成在线麻豆|