双向链表按顺序添加Node的时候,要先处理Node后面的指针,再处理Node前面的指针,原因在于:
如果先把Node和链表前半截连起来,链表前半截指向链表后半截的指针就没了,这样后半截链表就找不到了
先把Node和链表后半截连起来,这样由于Node是可以直接找到的,所以可以进行将Node和链表前半截连接的操作
public void addByOrder(Node node) {
Node temp = head;
while (true) {
if (temp.next == null) {
break;
}
if (temp.next.no >= node.no) {
break;
}
temp = temp.next;
}
if (temp.next != null) {
node.next = temp.next;
temp.next.pre = node;
}
temp.next = node;
node.pre = temp;
}
另外注意如果Node放到了链表最后一个位置,按照一种范式连接的时候,temp.next为null会出现空指针的问题,所以要加一个判断命令。
原文:https://www.cnblogs.com/LostSecretGarden/p/14665968.html