作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
现在我的链接列表处于队列形式。我的 LList 类包含两个名为 head 和 tail 的字段,它们是列表的头部和尾部。 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;
}
}
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());
}
}
最佳答案
您的代码对我来说看起来没问题,除非您删除的值是唯一的值 - 在这种情况下,您希望头部和尾部都为空。我怀疑你需要做的就是改变头套:
if (head.getVal() == v) {
head = head.getNext();
if (head != null) {
head.setPrev(null);
} else {
// If head.getNext() returns null, then tail must have been equal to head.
tail = null;
}
}
if (head == null) {
return;
}
while (tmp != null && tmp.getVal() != v) {
tmp = tmp.getNext();
}
if (tmp == null) {
return;
}
关于java - 需要有关链表删除方法的帮助,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15239138/
我是一名优秀的程序员,十分优秀!