从零开始的算法基础学习

(希望每天能挤点时间补充编程基础,以及这个学习笔记能够持续下去)

题目:

给你一个链表,删除链表的倒数第 `n` 个结点,并且返回链表的头结点。

最初想法:

(无)。

解法:双指针:

寻找目标节点+删除目标节点。

#寻找目标节点:

1:设置两个指针。两个指针的距离为n个节点。

指针1为快指针。领先旧指针n个距离。

指针2为慢指针。位置为第一个节点

原理:当指针1抵达节点的空指针时。意味着指针2找到了要删除的节点:

#删除目标节点

核心。找到那个节点后。倒退一格。

令point->next=point->next->next即可。

即跳过下一个指针。指向下下一个指针。

所以。最终要倒数第n+1个节点。

第一版本:

cpp 复制代码
class Solution{
    public:
    ListNode* DeleteChainNode(ListNode* head,int target){
        ListNode* fast=head;
        ListNode* slow=head;
        for(int i=0;i<=target;i++)
            fast=fast->next;
        };
        while(fast!=nullptr){
          fast=fast->next;
          slow=slow->next;
        }
        slow->next=slow->next->next;
    }
}

问题一:如果要删掉的是头节点。

例子:1 -> 2 -> 3, n = 3(删除倒数第3个,就是头节点1)

此时slow指针就要指向第-1个位置。也就是空指针。那么slow指针无效。

#解决方案

前置节点:

提前设置一个前置节点为最初链表的-1位置:

让前置节点指向链表的第一个头节点。即可

cpp 复制代码
ListNode* dummy=new ListNode(0);

        dummy->next=head;

        ListNode* fast=dummy;        ListNode* slow=dummy;

第二版:

cpp 复制代码
class Solution{

    public:

    ListNode* DeleteChainNode(ListNode* head,int target){

        ListNode* dummy=new ListNode(0);

        dummy->next=head;

        ListNode* fast=dummy;

        ListNode* slow=dummy;

        for(int i=0;i<=target;i++){

            fast=fast->next;

  

        };

        while(fast!=nullptr){

          fast=fast->next;

          slow=slow->next;

        }

        slow->next=slow->next->next;

        return head;

    }

  

};

问题:如果删除的是头节点。那么。head的位置就是个空指针。返回错误。

所以。应该返回:前置节点的下一个指针,即:dummy->next;

Q:为什么不是dummy?

A:因为dummy并不是链表最初的一部分。是设置的外部调节。返回的如果是dummy->next就可以保证不会被删掉。

相关推荐
不想睡觉_6 小时前
优先队列priority_queue
c++·算法
阿蒙Amon14 小时前
TypeScript学习-第10章:模块与命名空间
学习·ubuntu·typescript
AI绘画哇哒哒14 小时前
【干货收藏】深度解析AI Agent框架:设计原理+主流选型+项目实操,一站式学习指南
人工智能·学习·ai·程序员·大模型·产品经理·转行
那个村的李富贵14 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
power 雀儿14 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
琹箐15 小时前
最大堆和最小堆 实现思路
java·开发语言·算法
戌中横15 小时前
JavaScript——预解析
前端·javascript·学习
renhongxia115 小时前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了15 小时前
数据结构之树(Java实现)
java·算法