力扣19-删除链表中倒数第N个节点

删除链表中倒数第N个节点

题目链接

解题思路:

  1. 遍历链表,获得链表的长度size
  2. 删除倒数第N个节点,就是删除第size-N个节点
c++ 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
        int size = 0;
        ListNode *r = head;
        while(r != nullptr){
            size++;
            r = r->next;
        }//这层循环是为了获取链表的长度
        int s = size - n;//获取要删除的位置
        r = head;
        int index = 0;
        while(r){
            index++;
            if(index == s){
                r->next = r->next->next;//删除该节点
                break;
            }
            if(s==0){
                return head->next;//这种情况特判,删除的是头节点
            }
            r = r->next;
        }
        return head;
    }
};
相关推荐
ytttr8735 小时前
隐马尔可夫模型(HMM)MATLAB实现范例
开发语言·算法·matlab
AlenTech6 小时前
160. 相交链表 - 力扣(LeetCode)
数据结构·leetcode·链表
点云SLAM6 小时前
凸优化(Convex Optimization)理论(1)
人工智能·算法·slam·数学原理·凸优化·数值优化理论·机器人应用
jz_ddk7 小时前
[学习] 卫星导航的码相位与载波相位计算
学习·算法·gps·gnss·北斗
放荡不羁的野指针7 小时前
leetcode150题-动态规划
算法·动态规划
sin_hielo7 小时前
leetcode 1161(BFS)
数据结构·算法·leetcode
一起努力啊~7 小时前
算法刷题-二分查找
java·数据结构·算法
水月wwww7 小时前
【算法设计】动态规划
算法·动态规划
码农水水8 小时前
小红书Java面试被问:Online DDL的INSTANT、INPLACE、COPY算法差异
算法
iAkuya9 小时前
(leetcode)力扣100 34合并K个升序链表(排序,分治合并,优先队列)
算法·leetcode·链表