专栏名称: 吴师兄学算法
和程序员小吴一起从初学者的角度学习算法,以动画的形式呈现解题的思路。每周四篇原创文章,期待你的鉴赏!
目录
相关文章推荐
债市唤醒官  ·  2025-0225-给你们点信心!北风吹的锁 ... ·  2 天前  
债市唤醒官  ·  2025-0224-泥沙俱下~~ ·  3 天前  
毛有话说  ·  某官媒对2025年的神预测,让人背脊发凉… ·  2 天前  
ETF和LOF圈  ·  成交额连续突破2万亿 ·  3 天前  
并购优塾产业链地图  ·  地产高分红地图,三大央企开发商跟踪:华润置地 ... ·  3 天前  
51好读  ›  专栏  ›  吴师兄学算法

LeetCode 图解 | 206.反转链表

吴师兄学算法  · 公众号  ·  · 2020-02-20 12:15

正文

点击上方 蓝字 设为星标

下面开始今天的学习~

今天分享的题目来源于 LeetCode 上第 206 号问题:反转链表。这道题目经常出现在算法面试中的笔试环节。

题目描述

反转一个单链表。

示例:

输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

题目解析

在原链表之前建立一个空的节点 pre,然后从头节点 cur 开始,先保存 cur->next 为 next ,将 cur 的 next 节点变为 pre,pre 移到 cur,cur 移动到 next。

重复此操作直到 cur 成为末节点为止。

动画理解

参考代码

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */

class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode cur = head, pre = null;
        while (cur != null) {
            ListNode next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
       return pre;
    }
}

复杂度分析

  • 时间复杂度 :O(n)。

  • 空间复杂度 :O(1)。

相关题目推荐

  • LeetCode 26:删除排序数组中的重复项

  • LeetCode 203:移除链表元素


END



答应我,别再if/else走天下了可以吗







请到「今天看啥」查看全文