删除链表的节点

思路:

1.由于要进行删除操作,由于头结点是特殊的,所以为了同一操作,可以设置一个虚的头节点,连接到原链表的头结点

2.设置两个指针:一个指针pre(指向需要删除的节点的前一个节点),和一个指针cur(指向需要删除的节点)

代码:

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 *   public ListNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param head ListNode类 
     * @param val int整型 
     * @return ListNode类
     */
    public ListNode deleteNode (ListNode head, int val) {
        //对于删除链表节点和创建新的链表的操作,由于头节点的操作都是不同于其他节点的
        //所以为了同一操作,可以设置一个虚的头结点,连在原链表的头节点处
        ListNode dummynode=new ListNode(-1);
        dummynode.next=head;
        //设置两个指针pre和cur,分别指向需要删除的前一个节点和需要删除的节点
        //遇到需要删除的节点,就将前指针指向需要删除的节点的后一个节点
        ListNode pre=dummynode;
        ListNode cur=head;
        while(cur!=null){
            if(cur.val==val){
                pre.next=cur.next;
                break;
            }else{
                pre=cur;
                cur=cur.next;
            }
        }
        return dummynode.next;
    }
}