LeetCode 删除链表的倒数第N个结点

对于这种可能会删除头结点的题目:
1.先创建一个虚拟头结点dummy,再用头指针指向头结点
2.返回值为: dummy.next
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 removeNthFromEnd(ListNode head, int n) {
        List<Integer> arr=new ArrayList<Integer>();
        ListNode p=head;
        while(p!=null){
            arr.add(p.val);
            p=p.next;
        }
        int flag=arr.size()-n;
        ListNode dummy=new ListNode(-1);  //虚拟头结点,这样可以不用考虑是否删除的是第一个结点
        ListNode prev=dummy; //头指针指向头结点 
        prev.next=head;

        for(int i=0;i<flag;i++){
            prev=prev.next;
        }
        prev.next=prev.next.next;
        return dummy.next;

    }
}
相关推荐
I_LPL1 小时前
hot100贪心专题
数据结构·算法·leetcode·贪心
颜酱1 小时前
DFS 岛屿系列题全解析
javascript·后端·算法
WolfGang0073212 小时前
代码随想录算法训练营 Day16 | 二叉树 part06
算法
2401_831824963 小时前
代码性能剖析工具
开发语言·c++·算法
Sunshine for you4 小时前
C++中的职责链模式实战
开发语言·c++·算法
qq_416018724 小时前
C++中的状态模式
开发语言·c++·算法
2401_884563244 小时前
模板代码生成工具
开发语言·c++·算法
2401_831920744 小时前
C++代码国际化支持
开发语言·c++·算法
m0_672703315 小时前
上机练习第51天
数据结构·c++·算法
ArturiaZ5 小时前
【day60】
算法·深度优先·图论