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;
    }
}
相关推荐
MMjeaty25 分钟前
map/multimap容器
数据结构·c++
zstar-_36 分钟前
【不背八股】12.十大排序算法
数据结构·算法·排序算法
吃着火锅x唱着歌43 分钟前
LeetCode 2110.股票平滑下跌阶段的数目
数据结构·算法·leetcode
疋瓞2 小时前
C++_STL和数据结构《1》_STL、STL_迭代器、c++中的模版、STL_vecto、列表初始化、三个算法、链表
数据结构·c++·算法
JJJJ_iii2 小时前
【左程云算法09】栈的入门题目-最小栈
java·开发语言·数据结构·算法·时间复杂度
小猪咪piggy3 小时前
【算法】day2 双指针+滑动窗口
数据结构·算法·leetcode
budingxiaomoli3 小时前
AVL树知识总结
数据结构·算法
小狮子安度因5 小时前
ffplay数据结构分析
数据结构·ffmpeg
kyle~11 小时前
排序---插入排序(Insertion Sort)
c语言·数据结构·c++·算法·排序算法
2301_7703737312 小时前
数据结构之跳表
数据结构