算法竞赛备赛——【数据结构】链表

链表

原地逆置

206. 反转链表 - 力扣(LeetCode)

C++ 复制代码
class Solution {
public:
    ListNode* reverseList(ListNode* head) {//链表无头节点 原地逆置 
        ListNode* pre=head;
        ListNode* cur=NULL;
        ListNode* t=NULL;//t=head->next 若head指向空链表会报错 非法访问其他空间
        while(pre!=NULL){
            t=pre->next;
            pre->next=cur;
            cur=pre;
            pre=t;
        }
        head=cur;
        return head;
    }
};

快慢指针

LCR 140. 训练计划 II - 力扣(LeetCode)

让两个指针相差k个 只用遍历一轮

C++ 复制代码
class Solution {
public:
    ListNode* trainingPlan(ListNode* head, int cnt) {
        ListNode* f=head;//fast
        ListNode* s=head;//slow
        int count=0;
        while(f!=NULL&&count<cnt){
            count++;
            f=f->next;
        }
        while(f!=NULL){
            f=f->next;
            s=s->next;
        }
        return s;
    }
};

静态链表

用数组描述的链表

跳表

跳跃表、跳跃列表,在有序链表的基础上增加了"跳跃"的功能,有序链表实现而二分查找。

1206. 设计跳表 - 力扣(LeetCode)

有点复杂 暂时不需要做

相关推荐
爱干饭的boy2 分钟前
Leetcode—454. 四数相加 II(STL的map AND 基础算法)
开发语言·数据结构·c++·算法·leetcode
一只_程序媛3 分钟前
【leetcode hot 100 79】单词搜索
算法
C++ 老炮儿的技术栈28 分钟前
squirrel语言全面介绍
开发语言·c++·笔记·学习
我欲混吃与等死33 分钟前
LeetCode 21Merge Two Sorted Lists 合并两个排序链表 Java
java·leetcode·链表
Elizahone33 分钟前
【经典题目】逆序对的数量 离散化技巧
算法·树状数组·归并分治·离散化技巧
滨HI01 小时前
蓝桥杯2024B组
职场和发展·蓝桥杯
夜松云1 小时前
线性代数核心概念与NumPy科学计算实战全解析
数据结构·人工智能·python·线性代数·算法·机器学习·numpy
空白木各1 小时前
2Dslam前端分类
人工智能·算法·分类
小乌龟登顶记1 小时前
C++23新特性详解:迈向更现代化的C++
c++
Source.Liu2 小时前
【CXX-Qt】2.3 类型
c++·qt·rust