現在我的鏈接列表處於隊列形式。我的LList類包含兩個稱爲頭部和尾部的字段,它們是列表的頭部和尾部。頭部和尾部是LNode對象,LNode是包含int值的列表元素,它是之前的LNode和下一個LNode。需要關於鏈接列表刪除方法的幫助
這裏是我的葉子節點類:
class LNode{
private int val;
private LNode next;//not recursive
private LNode prev;
public LNode(int v, LNode n, LNode p){
next = n;
prev = p;
val = v;
}
public int getVal(){
return val;
}
public LNode getNext(){
return next;
}
public LNode getPrev(){
return prev;
}
public void setVal(int v){
val = v;
}
public void setNext(LNode n){
next = n;
}
public void setPrev(LNode p){
prev = p;
}
}
我試圖做一個刪除方法在我LLIST類,因此,它需要一個值,並刪除了該值的葉子節點。我的問題是,我不知道如何處理我試圖刪除的LNode是頭部還是尾部的情況。
public void delete(int v){
if(head.getVal()==v){//delete head
head = head.getNext();
head.setPrev(null);
}
else if(tail.getVal()==v){//delete tail
System.out.println("boiboi");
tail = tail.getPrev();
tail.setNext(null);
}
else{//delete other element
LNode tmp = head;
while(tmp.getVal()!=v){
tmp = tmp.getNext();
}
tmp.getPrev().setNext(tmp.getNext());
tmp.getNext().setPrev(tmp.getPrev());
}
}
我試過的是設置新的頭以前的LNode爲空,但Java不允許。所以我該怎麼做?
謝謝。
它可以是一個循環列表嗎?在這種情況下,你可以'head.setPrev(tail)'。 – 2013-03-06 04:46:56
「Java不允許」是什麼意思? – 2013-03-06 04:47:09
我不這麼認爲......它必須是隊列 – 2013-03-06 04:47:40