【剑指offer】面试题18:删除链表的节点(Java)

给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。

返回删除后的链表的头节点。

注意:此题对比原题有改动

示例 1:

输入: head = [4,5,1,9], val = 5
输出: [4,1,9]
解释: 给定你链表中值为 5 的第二个节点,那么在调用了你的函数之后,该链表应变为 4 -> 1 -> 9.
示例 2:

输入: head = [4,5,1,9], val = 1
输出: [4,5,9]
解释: 给定你链表中值为 1 的第三个节点,那么在调用了你的函数之后,该链表应变为 4 -> 5 -> 9.
 

代码:

/**

 * Definition for singly-linked list.

 * public class ListNode {

 *     int val;

 *     ListNode next;

 *     ListNode(int x) { val = x; }

 * }

 */

class Solution {

    public ListNode deleteNode(ListNode head, int val) {

        if(head.val==val)

        {

            head = head.next;

            return head;

        }

        ListNode p=head,q=p.next;

        while(q!=null&&q.next!=null)

        {

            if(q!=null&&q.val!=val)

            {

                p = q;

                q =q.next;

            }

            else if(q.val==val)

            {

                p.next = q.next;

               // System.out.println(p.val);

                return head;

            }

        }

        if(q.val==val)

        {

            p.next=null;

        }

        return head;

    }

}

发布了275 篇原创文章 · 获赞 9 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/hx1043116928/article/details/104618485