亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

Java語言中鏈表和雙向鏈表

2020-03-24 19:28:16
字體:
來源:轉載
供稿:網友
鏈表是一種重要的數據結構,在程序設計中占有很重要的地位。C語言和C++語言中是用指針來實現鏈表結構的,由于Java語言不提供指針,所以有人認為在Java語言中不能實現鏈表,其實不然,Java語言比C和C++更容易實現鏈表結構。Java語言中的對象引用實際上是一個指針(本文中的指針均為概念上的意義,而非語言提供的數據類型),所以我們可以編寫這樣的類來實現鏈表中的結點。

html' target='_blank'>class Node
{
Object data;
Node next;//指向下一個結點
}

將數據域定義成Object類是因為Object類是廣義超類,任何類對象都可以給其賦值,增加了代碼的通用性。為了使鏈表可以被訪問還需要定義一個表頭,表頭必須包含指向第一個結點的指針和指向當前結點的指針。為了便于在鏈表尾部增加結點,還可以增加一指向鏈表尾部的指針,另外還可以用一個域來表示鏈表的大小,當調用者想得到鏈表的大小時,不必遍歷整個鏈表。下圖是這種鏈表的示意圖: 鏈表的數據結構

我們可以用類List來實現鏈表結構,用變量Head、Tail、Length、Pointer來實現表頭。存儲當前結點的指針時有一定的技巧,Pointer并非存儲指向當前結點的指針,而是存儲指向它的前趨結點的指針,當其值為null時表示當前結點是第一個結點。那么為什么要這樣做呢?這是因為當刪除當前結點后仍需保證剩下的結點構成鏈表,如果Pointer指向當前結點,則會給操作帶來很大困難。那么如何得到當前結點呢,我們定義了一個方法cursor(),返回值是指向當前結點的指針。類List還定義了一些方法來實現對鏈表的基本操作,通過運用這些基本操作我們可以對鏈表進行各種操作。例如reset()方法使第一個結點成為當前結點。insert(Object d)方法在當前結點前插入一個結點,并使其成為當前結點。remove()方法刪除當前結點同時返回其內容,并使其后繼結點成為當前結點,如果刪除的是最后一個結點,則第一個結點變為當前結點。

鏈表類List的源代碼如下:

import java.io.*;
public class List
{
/*用變量來實現表頭*/
private Node Head=null;
private Node Tail=null;
private Node Pointer=null;
private int Length=0;
public void deleteAll()
/*清空整個鏈表*/
{
Head=null;
Tail=null;
Pointer=null;
Length=0;
}
public void reset()
/*鏈表復位,使第一個結點成為當前結點*/
{
Pointer=null;
}
public boolean isEmpty()
/*判斷鏈表是否為空*/
{
return(Length==0);
}
public boolean isEnd()
/*判斷當前結點是否為最后一個結點*/
{
if(Length==0)
throw new java.lang.NullPointerException();
else if(Length==1)
return true;
else
return(cursor()==Tail);
}
public Object nextNode()
/*返回當前結點的下一個結點的值,并使其成為當前結點*/
{
if(Length==1)
throw new java.util.NoSuchElementException();
else if(Length==0)
throw new java.lang.NullPointerException();
else
{
Node temp=cursor();
Pointer=temp;
if(temp!=Tail)
return(temp.next.data);
else
throw new java.util.NoSuchElementException();
}
}
public Object currentNode()
/*返回當前結點的值*/
{
Node temp=cursor();
return temp.data;
}

public void insert(Object d)
/*在當前結點前插入一個結點,并使其成為當前結點*/
{
Node e=new Node(d);
if(Length==0)
{
Tail=e;
Head=e;
}
else
{
Node temp=cursor();
e.next=temp;
if(Pointer==null)
Head=e;
else
Pointer.next=e;
}
Length++;
}
public int size()
/*返回鏈表的大小*/
{
return (Length);
}
public Object remove()
/*將當前結點移出鏈表,下一個結點成為當前結點,如果移出的結點是最后一個結點,則第一個結點成為當前結點*/
{
Object temp;
if(Length==0)
throw new java.util.NoSuchElementException();
else if(Length==1)
{
temp=Head.data;
deleteAll();
}
else
{
Node cur=cursor();
temp=cur.data;
if(cur==Head)
Head=cur.next;
else if(cur==Tail)
{
Pointer.next=null;
Tail=Pointer;
reset();
}
else
Pointer.next=cur.next;
Length--;
}
return temp;
}
private Node cursor()
/*返回當前結點的指針*/
{
if(Head==null)
throw new java.lang.NullPointerException();
else if(Pointer==null)
return Head;
else
return Pointer.next;
}
public static void main(String[] args)
/*鏈表的簡單應用舉例*/
{
List a=new List ();
for(int i=1;i i++)
a.insert(new Integer(i));
System.out.println(a.currentNode());
while(!a.isEnd())
System.out.println(a.nextNode());
a.reset();
while(!a.isEnd())
{
a.remove();
}
a.remove();
a.reset();
if(a.isEmpty())
System.out.println("There is no Node in List /n");
System.in.println("You can press return to quit/n");
try
{
System.in.read();
//確保用戶看清程序運行結果
}
catch(IOException e)
{}
}
}
class Node
/*構成鏈表的結點定義*/
{
Object data;
Node next;
Node(Object d)
{
data=d;
next=null;
}
}

讀者還可以根據實際需要定義新的方法來對鏈表進行操作。雙向鏈表可以用類似的方法實現只是結點的類增加了一個指向前趨結點的指針。

可以用這樣的代碼來實現:

class Node
{
Object data;
Node next;
Node previous;
Node(Object d)
{
data=d;
next=null;
previous=null;
}
}

當然,雙向鏈表基本操作的實現略有不同。鏈表和雙向鏈表的實現方法,也可以用在堆棧和隊列的實現中,這里就不再多寫了,有興趣的讀者可以將List類的代碼稍加改動即可。html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩高清中文字幕| 成人免费视频网址| 91在线免费网站| 欧洲永久精品大片ww免费漫画| 日韩精品在线观看网站| 久久久成人精品| 欧美在线免费看| 欧美午夜精品久久久久久久| 欧美另类极品videosbestfree| 91九色在线视频| 国产精品免费一区豆花| 精品久久久久久中文字幕大豆网| 亚洲视频日韩精品| 日韩亚洲综合在线| 国产成人精品免费久久久久| 欧美中文字幕第一页| 欧美性videos高清精品| 成人免费激情视频| 激情亚洲一区二区三区四区| 亚洲色图av在线| 欧美国产极速在线| 亚洲第一综合天堂另类专| 欧美日韩中文字幕在线| 国产成人精彩在线视频九色| 久久亚洲精品视频| 中文字幕在线看视频国产欧美在线看完整| 亚洲成人黄色网址| 国产精品成人观看视频国产奇米| 欧美精品在线免费观看| 日韩av在线影视| 日韩国产在线播放| 日韩在线免费高清视频| 97精品一区二区三区| 精品视频9999| 国产精品69久久| 91麻豆国产语对白在线观看| 韩国欧美亚洲国产| 欧美一级电影免费在线观看| 91在线观看免费观看| 亚洲天堂成人在线| 欧美亚洲国产视频小说| 4438全国亚洲精品在线观看视频| 国产精品久久久久aaaa九色| 午夜欧美不卡精品aaaaa| 亚洲人成电影在线观看天堂色| 伊人精品在线观看| 91久久久久久久一区二区| 欧美黄色片在线观看| 欧美整片在线观看| 亚洲国产精品久久91精品| 91av在线影院| 色噜噜国产精品视频一区二区| 欧美一级黄色网| 高跟丝袜欧美一区| 久久99久久久久久久噜噜| 5252色成人免费视频| 中文字幕亚洲自拍| 欧美裸体男粗大视频在线观看| 亚洲第一福利网站| 91免费综合在线| 久久久免费精品视频| 亚洲福利视频久久| 亚洲已满18点击进入在线看片| 91久久久久久久久久久久久| 91夜夜未满十八勿入爽爽影院| 国产日韩中文字幕| 国产精品视频久| 欧美日韩xxx| 中文字幕一区二区三区电影| 亚洲天堂男人天堂女人天堂| 国产大片精品免费永久看nba| 国产精品揄拍500视频| 日本午夜人人精品| 92裸体在线视频网站| 高清欧美性猛交xxxx黑人猛交| 91精品国产高清久久久久久久久| 国产亚洲精品久久久久动| 91九色在线视频| 国产成人avxxxxx在线看| 不卡av在线播放| 久久久久久久网站| 国产精品自产拍在线观看| 国产精品小说在线| 久久国产精品免费视频| 高跟丝袜欧美一区| 一区二区三区高清国产| 中文字幕国产精品| 精品亚洲夜色av98在线观看| 九九热最新视频//这里只有精品| 亚洲综合最新在线| 欧美国产日韩视频| 2021久久精品国产99国产精品| 久久精品视频中文字幕| 国内精品久久久久影院优| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲日本成人网| 国产成人精品视频| 久久久国产成人精品| 亚洲精品小视频| 91精品国产高清久久久久久| 亚洲精品在线观看www| 色悠悠久久久久| 欧美日韩在线另类| 中文字幕av一区二区三区谷原希美| 在线看日韩av| 久久久国产精品亚洲一区| 久久国产精品99国产精| 成人亚洲综合色就1024| 日韩国产高清污视频在线观看| 91系列在线播放| 欧美日韩在线一区| 97超级碰碰人国产在线观看| 精品视频在线播放| 欧美视频二区36p| 亚洲美女av在线播放| 国产成人精品视频在线| 亚洲第一区中文字幕| 国产日韩欧美中文| 久久久久久久久综合| 欧美福利在线观看| 欧美在线一区二区视频| 国产精品成人观看视频国产奇米| 精品一区二区三区四区| 日韩在线观看网址| 国产区精品在线观看| 亚洲成人免费在线视频| 久久福利网址导航| 97国产精品视频人人做人人爱| 久久久久久久久久婷婷| 日本高清不卡在线| 久久在线免费视频| 精品亚洲夜色av98在线观看| 精品毛片三在线观看| 亚洲成人av在线| 在线观看日韩视频| 欧美一级在线播放| 亚洲免费电影在线观看| 久久久999国产精品| 国产精品∨欧美精品v日韩精品| 中文字幕日韩av| 久久人人爽人人爽人人片av高清| 在线观看欧美视频| 日韩av电影手机在线观看| 欧美一性一乱一交一视频| 国产91免费观看| 国产精品视频xxxx| 5566日本婷婷色中文字幕97| 亚洲综合社区网| 亚洲激情成人网| 日韩综合视频在线观看| 久久国产精品免费视频| 日韩va亚洲va欧洲va国产| 中文字幕综合在线| 精品美女永久免费视频| 日韩视频在线免费| 精品国产91乱高清在线观看| 成人国产亚洲精品a区天堂华泰| 欧美高清理论片| 91精品久久久久久久久| 日本一区二三区好的精华液| 国语自产精品视频在线看一大j8| 亚洲精品视频播放| 国产精品久久久久久久9999| 欧美黄色三级网站|