2026.1.20力扣刷题笔记

题目:

解答:

cpp 复制代码
struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode* fast=head;
    struct ListNode* slow=head;
    while(fast!=NULL){
        slow=slow->next;
        if(fast->next!=NULL)
            fast=fast->next->next;
        else
        return NULL;
        if(fast==slow){
            struct ListNode* p=head;
            while (p != slow) {
                p = p->next;
                slow = slow->next;
            }
            return p;
        }
    }return NULL;
}
cpp 复制代码
class Solution {
public:
    ListNode *detectCycle(ListNode *head) {
        unordered_set<ListNode*> visited;
        while(head!=nullptr){//NULL时空整数,nullptr表示空指针
            if(visited.count(head)){//计算统计head在集合里面出现几次,出现过即入口指针
            return head;
            }
            visited.insert(head);
            head=head->next;
        }
        return nullptr;
    }
};
心得:法一是王道原题,记得当时就是根据快慢指针指向不同而作为解法,abc为三段,快慢相遇时有如下表达式,所以能推算出b。
法二:用哈希指针集合表示,count函数来判定出现的次数,返回nullptr代表无环。

题目:

解答:

cpp 复制代码
struct ListNode* removeNthFromEnd(struct ListNode* head, int n) {
    int count=0;
    struct ListNode* p=head;
    struct ListNode* dummy=(struct ListNode*)malloc(sizeof(struct ListNode));
    dummy->next=head;
    for(p;p!=NULL;p=p->next)
        count++;
    if(count<n)
    return NULL;
    p=dummy;
    for(int i=0;i<count-n;i++){
        p=p->next;
    }
    struct ListNode* q=p->next;
    p->next=p->next->next;
    free(q);
    return dummy->next;
}
心得:使用哑节点,便于处理头结点,然后找到要删除的点(count-n),删除节点然后释放空间。需要注意的是,dummy需要申请空间,防止变成野指针。

题目:

解答:

cpp 复制代码
struct ListNode* swapPairs(struct ListNode* head) {
    struct ListNode* dummy = (struct ListNode*)malloc(sizeof(struct ListNode));
    dummy->next = head;
    struct ListNode* prev = dummy;
    while(prev->next!=NULL&&prev->next->next!=NULL){
        struct ListNode* first=prev->next;
        struct ListNode* second=first->next;
        prev->next=second;
        first->next=second->next;
        second->next=first;
        prev=first;
    }
    return dummy->next;
}
心得:我原本想的思路是创建一个新的链表,先指向所有偶次链表节点,然后插入所有奇数链表节点,但是实现起来琐碎且复杂。答案采用直接dummy链接整个head链表,再内部调整两个节点的顺序,代码超级简单,记住这种思路。
相关推荐
有时间要学习9 分钟前
面试150——第五周
算法·深度优先
The森18 分钟前
Linux IO 模型纵深解析 01:从 Unix 传统到 Linux 内核的 IO 第一性原理
linux·服务器·c语言·经验分享·笔记·unix
tq108623 分钟前
Skills 的问题与解决方案
笔记
三水不滴32 分钟前
有 HTTP 了为什么还要有 RPC?
经验分享·笔记·网络协议·计算机网络·http·rpc
三块可乐两块冰1 小时前
【第二十九周】机器学习笔记三十
笔记
晚霞的不甘1 小时前
Flutter for OpenHarmony 可视化教学:A* 寻路算法的交互式演示
人工智能·算法·flutter·架构·开源·音视频
望舒5131 小时前
代码随想录day25,回溯算法part4
java·数据结构·算法·leetcode
C++ 老炮儿的技术栈1 小时前
Qt 编写 TcpClient 程序 详细步骤
c语言·开发语言·数据库·c++·qt·算法
KYGALYX1 小时前
逻辑回归详解
算法·机器学习·逻辑回归
听麟2 小时前
HarmonyOS 6.0+ 跨端智慧政务服务平台开发实战:多端协同办理与电子证照管理落地
笔记·华为·wpf·音视频·harmonyos·政务