删除链表节点
总结一下高频常用的删除链表结点的情况,无论对链表进行何种操作,都需要精确查找和精确指向。另外,在删除链表节点时有一个很好用的技巧:虚头结点,将头结点的特殊性转化为一般,在后面具体阐述。
删除特定节点
常用方法:直接模拟
关键:精确找到特定节点,并且将其cur.next
指向cur.next.next
。
由于可能删除头结点,可以引入一个虚头结点dummyHead
,来使得操作头结点的特殊性变得一般化,不用单独处理头结点,就和其它节点同等对待。
Code
public static ListNode removeElements(ListNode head, int val) {
ListNode dummyHead = new ListNode();
//虚头结点的next指向头结点head
dummyHead.next = head;
ListNode cur = dummyHead;
while (cur.next != null) {
if (cur.next.val == val) {
//跳过一个节点指向,实现删除
cur.next = temp.next.next;
} else {
cur = temp.next;
}
}
//注意虚节点的next一定是真正的删除操作过后的链表头结点
return dummyHead.next;
}
删除倒数第K个节点
常用方法:双指针
关键:引入虚头结点,慢指针初始化在虚头节点,快指针初始化在原来的头节点,注意这里快节点是要走到null而不是它的下一个为null停止,因为这里快慢指针本来就有一位差距(倒也是好理解,如果都初始化在虚头节点则判定快节点的下一个为null)。
最后记得返回的是dummyHead.next
。
Code
public static ListNode removeNthFromEndByTwoPoints(ListNode head, int n) {
ListNode dummyHead = new ListNode(0);
dummyHead.next = head;
ListNode fast= head;
ListNode slow = dummyHead;
while (n > 0){
fast = fast.next;
n--;
}
while (fast != null) {
fast = fast.next;
slow = slow.next;
}
slow.next = slow.next.next;
return dummyHead.next;
}
删除重复元素
重复元素保留一个
常用方法:直接模拟
关键:真就直接模拟,没有任何套路,没有任何心机,就像Bob一样。
Code
public ListNode deleteDuplicates(ListNode head) {
if(head == null){
return head;
}
ListNode cur = head;
while(cur.next != null){
if(cur.val == cur.next.val){
cur.next = cur.next.next;
}else{
cur = cur.next;
}
}
return head;
}
重复元素全删
常用方法:直接模拟
关键:注意引入虚头节点并从虚头结点开始寻找,比较cur.next.val
和cur.next.next.val
是否相等,如果相等,说明这个值是重复的,将其暂存。
然后再往后找,并比较后面的节点值是否还为这个重复值。遇到了就将其删去(指向跳过)。
注意,由于一下往下看了两位节点,搜索要在它们都不为空的情况下进行。
Code
public ListNode deleteDuplicates(ListNode head) {
if (head == null) {
return head;
}
ListNode dummy = new ListNode(-1111, head);
ListNode cur = dummy;
while (cur.next != null && cur.next.next != null) {
if (cur.next.val == cur.next.next.val) {
//关键在这个每一次都记录这个重复的数值
int k = cur.next.val;
//再消去所有val为这个重复数值的节点
while (cur.next != null && cur.next.val == k) {
cur.next = cur.next.next;
}
} else {
cur = cur.next;
}
}
return dummy.next;
}
原文地址:https://blog.csdn.net/qq_60551096/article/details/134700169
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_9209.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!