leetcode-206-翻转链表

  • 对于链表来说,->next就是代表图上的那个箭头,指向后,就相当于已经建立完链接,就可以改变只想节点的指针的位置了

  • 每一个指针,则是代表一个圈

一 解题

方法一:迭代
假设链表为 1→2→3→∅1 \rightarrow 2 \rightarrow 3 \rightarrow \varnothing1→2→3→∅,我们想要把它改成 ∅←1←2←3\varnothing \leftarrow 1 \leftarrow 2 \leftarrow 3∅←1←2←3。

在遍历链表时,将当前节点的 next\textit{next}next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。

class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        ListNode* curr = head;
        while (curr) {
//如果要改变链接指向,则需要暂存现在的指向
            ListNode* next = curr->next;
//断开链接,并重新链接
            curr->next = prev;
            prev = curr;
            curr = next;
        }
        return prev;
    }
};

相关推荐

  1. leetcode-206-翻转

    2024-02-08 18:24:01       56 阅读
  2. Golang leetcode206 翻转 迭代 递归 双指针

    2024-02-08 18:24:01       60 阅读
  3. LeetCode206相交

    2024-02-08 18:24:01       54 阅读
  4. leetcode206. 反转

    2024-02-08 18:24:01       65 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-08 18:24:01       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-08 18:24:01       106 阅读
  3. 在Django里面运行非项目文件

    2024-02-08 18:24:01       87 阅读
  4. Python语言-面向对象

    2024-02-08 18:24:01       96 阅读

热门阅读

  1. 210 springcloud常见面试题

    2024-02-08 18:24:01       56 阅读
  2. 2.5作业

    2024-02-08 18:24:01       44 阅读
  3. 51单片机基础(C语言):定时器时钟

    2024-02-08 18:24:01       56 阅读
  4. 使用Spring AOP实现对外接口的日志自动打印

    2024-02-08 18:24:01       59 阅读
  5. Leetcode 198 打家劫舍

    2024-02-08 18:24:01       43 阅读
  6. 百粉福预告!!!

    2024-02-08 18:24:01       54 阅读