現在、リンク リストはキュー形式になっています。私の LList クラスには、リストの先頭と末尾である head と tail という 2 つのフィールドがあります。head と tail は LNode オブジェクトであり、LNode は int 値を保持するリストの要素であり、前の LNode と次の 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 を削除しようとしています。私の問題は、削除しようとしている 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 を null に設定することですが、Java はそれを許可しません。それで、私は何をすべきですか?
ありがとうございました。