力扣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;
    }
};
相关推荐
forestsea6 分钟前
现代 JavaScript 加密技术详解:Web Crypto API 与常见算法实践
前端·javascript·算法
张洪权10 分钟前
bcrypt 加密
算法
快手技术18 分钟前
视频理解霸榜!快手 Keye-VL 旗舰模型重磅开源,多模态视频感知领头羊
算法
骑自行车的码农1 小时前
🍂 React DOM树的构建原理和算法
javascript·算法·react.js
CoderYanger2 小时前
优选算法-优先级队列(堆):75.数据流中的第K大元素
java·开发语言·算法·leetcode·职场和发展·1024程序员节
希望有朝一日能如愿以偿2 小时前
力扣每日一题:能被k整除的最小整数
数据结构·算法·leetcode
Controller-Inversion2 小时前
力扣53最大字数组和
算法·leetcode·职场和发展
rit84324992 小时前
基于感知节点误差的TDOA定位算法
算法
m0_372257022 小时前
ID3 算法为什么可以用来优化决策树
算法·决策树·机器学习
q***25212 小时前
SpringMVC 请求参数接收
前端·javascript·算法