【leetcode 06】203.移除链表元素

要点⭐

1.链表的遍历

2.链表指针的改变

3.要考虑头节点的移除

原链表删除元素

直接使用原来的链表来进行删除操作。

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode removeElements(ListNode head, int val) {
        //使用原链表进行删除
        while(head!=null&&head.val==val){
            head=head.next;
        }
        ListNode cur=head;
        while(cur!=null&&cur.next!=null){
            if(cur.next.val==val){
                cur.next=cur.next.next;
            }else{
                cur=cur.next;
            }
        }
     return head;   
    }
}

使用虚拟头节点删除元素

设置一个虚拟头结点在进行删除操作。

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode removeElements(ListNode head, int val) {
        //使用虚拟头节点
        ListNode dummy=new ListNode();
        dummy.next=head;
        ListNode cur=dummy;
        while(cur.next!=null){
            if(cur.next.val==val){
                cur.next=cur.next.next;
            }else{
                cur=cur.next;
            }
        }
     return dummy.next;   
    }
}
相关推荐
叶子202422几秒前
labelme下载
java·jvm·算法
V+zmm1013418 分钟前
基于微信小程序的快递管理平台的设计与实现ssm+论文源码调试讲解
java·微信小程序·小程序·毕业设计·ssm
小七蒙恩22 分钟前
java下载文件流,不生成中间文件。
java·开发语言·状态模式
计算机萍萍学姐33 分钟前
ArrayList和LinkedList的区别是什么?
java·数据结构·算法
李老头探索34 分钟前
Java List 集合详解:基础用法、常见实现类与高频面试题解析
java·list
黑风风42 分钟前
使用 `@Async` 实现 Spring Boot 异步编程
java·spring boot·后端
等一场春雨1 小时前
Spring Boot 3 文件下载、多文件下载以及大文件分片下载、文件流处理、批量操作 和 分片技术
java·spring boot·后端
码喽不秃头1 小时前
java中的特殊文件
java·开发语言
听风吟丶1 小时前
深入探究 Java hashCode:核心要点与实战应用
java·开发语言
【D'accumulation】1 小时前
深入聊聊typescript、ES6和JavaScript的关系与前瞻技术发展
java·开发语言·前端·javascript·typescript·es6