day-36 删除链表的倒数第 N 个结点

思路

首先计算出链表的长度,然后删除第n个节点即可,但要注意考虑特殊情况

解题方法

特殊情况:1.删除节点为最后一个节点

2.删除节点为头结点

Code

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) {
        ListNode t=head;
        int len=0;
        while(t!=null){
            len++;
            t=t.next;
        }
        if(n==len) return head.next;
        t=head;
        for(int i=1;i<len-n;i++){
            t=t.next;
        }
        if(t.next==null){
            t=null;
        }else if(t.next.next!=null){
            t.next=t.next.next;
        }else{
            t.next=null;
        }
        return head;
    }
}
相关推荐
ValhallaCoder6 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
月挽清风7 小时前
代码随想录第十五天
数据结构·算法·leetcode
NEXT068 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
小妖66611 小时前
js 实现快速排序算法
数据结构·算法·排序算法
独好紫罗兰13 小时前
对python的再认识-基于数据结构进行-a003-列表-排序
开发语言·数据结构·python
wuhen_n14 小时前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
2401_8414956414 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
独好紫罗兰14 小时前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_8414956414 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
数智工坊14 小时前
【数据结构-树与二叉树】4.5 线索二叉树
数据结构