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

链表

原地逆置

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)

有点复杂 暂时不需要做

相关推荐
通信小呆呆几秒前
从理想到现实:实际系统中非理想特性及其补偿方法
算法·数学建模·信号处理
_wyt001几秒前
洛谷P15799 [GESP202603 五级] 找数 题解
c++·gesp
AI人工智能+电脑小能手5 分钟前
【大白话说Java面试题 第97题】【Mysql篇】第27题:说说分库与分表的设计?
java·开发语言·数据库·分布式·mysql·算法
困意少年7 分钟前
C++11 如何减少无意义的拷贝:右值引用、`std::move`、移动语义与完美转发
c++
apcipot_rain12 分钟前
计科八股20260605——软件生命周期、文档、死锁、地址转换、I/O控制方式、堆、无向图、连通图、最小支配集、逆关系、永真式
数据结构·操作系统·软件工程·计算机组成原理·离散数学
yuan1999713 分钟前
双目视觉测距实现
算法
洒脱的六边形战士加辣14 分钟前
Java排序方法全解析
java·数据结构·算法
代码中介商24 分钟前
LRU缓存算法:双向链表+哈希表实现
算法·链表·缓存
lqqjuly28 分钟前
计算理论—图灵机、复杂性、信息论与机器学习的理论基础
算法
Hiter_John41 分钟前
Golang的循环语句
开发语言·算法·golang