本文共 1062 字,大约阅读时间需要 3 分钟。
package SwordOffer;/** * @Description: 给定单向链表的头指针和一个要删除的节点的值,定义一个函数删除该节点。返回删除后的链表的头节点。注意:此题对比原题有改动示例 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. 说明:题目保证链表中节点的值互不相同若使用 C 或 C++ 语言,你不需要 free 或 delete 被删除的节点来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/shan-chu-lian-biao-de-jie-dian-lcof著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。* @Param: * @return: * @Author: lvhong* @Date: * @E-mail lvhong282@163.com*/ public class lab18easy { public class ListNode { int val; ListNode next; ListNode(int x) { val = x; } } public ListNode deleteNode(ListNode head, int val) {//单指针 if (head.val == val) { return head.next; } ListNode pos = head; while (pos.next != null) { if (pos.next.val == val) { break; } else { pos = pos.next; } } pos.next = pos.next.next; return head; }}