LeetCode 206 - 反转链表

解题思路

  1. 我们可以使用迭代的方法来实现链表的反转,这里我们先介绍迭代的方法。
  2. 迭代的思路是:从头节点开始,依次将节点的next指针进行反转,使得当前节点的next指向其前一个节点,然后依次向后移动指针,直至链表末尾。
  3. 反转过程中需要用到三个指针:prev表示前一个节点,curr表示当前节点,nextTemp表示下一个节点。在每次迭代中,需要先记录下nextTemp,然后将当前节点的next指向prev,最后将prev和curr向后移动。

算法实现

C++实现

cpp 复制代码
/**
 * 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* reverseList(ListNode* head) {
        ListNode*cur=head;
        ListNode*pre=NULL;
        while(cur)
        {
            ListNode*tmp=cur->next;
            cur->next=pre;
            pre=cur;
            cur=tmp; 
        }
        return pre;
    }
};

复杂度分析

  • 时间复杂度:O(n),其中n是链表的长度。需要访问链表的所有节点进行反转操作。
  • 空间复杂度:O(1),只使用了常数级别的额外空间。

总结

通过迭代的方法,我们可以高效地实现链表的反转操作,并且时间复杂度和空间复杂度都相对较低。这样的实现方法在实际应用中具有较好的性能表现和可扩展性,适用于大规模的链表数据。

希望这篇博客能对你有所帮助,如果有任何问题,欢迎和我一起讨论。

相关推荐
Swift社区5 小时前
OpenHarmony鸿蒙PC平台移植 gifsicle:CC++ 三方库适配实践(Lycium tpc_c_cplusplus)
c语言·c++·harmonyos
foundbug9995 小时前
最优化问题的外点罚函数法与内点罚函数法-MATLAB实现
开发语言·matlab
凯瑟琳.奥古斯特5 小时前
力扣1001网格照明解法
算法·leetcode·职场和发展
弹简特5 小时前
【零基础学Python】05-Python函数完全指南:从初阶定义到进阶参数,一篇打通核心难点
开发语言·python
AugustRed5 小时前
A2UI 完整学习指南(含 Java 后端 + 前端实战示例)
java·开发语言·前端
jingling5555 小时前
自建技术博客实战(三):工具专栏——地图定位、声音复刻与 rembg 抠图
android·开发语言·前端·ai·nextjs
basketball6165 小时前
C++进阶:1. 引用折叠规则
java·开发语言·c++
酬勤-人间道5 小时前
VTK 与 Cesium-native 结合实践:小场景三维编辑 + 数字地球精准贴合
c++·qt·vtk·遥感·岩土·cesium-native
智者知已应修善业5 小时前
【51单片机8个LED的花样12亮34熄56间隔78闪烁3秒3闪烁】2023-11-4
c++·经验分享·笔记·算法·51单片机
初中就开始混世的大魔王5 小时前
5 Fast DDS-Discovery
网络·c++·算法·中间件