LeetCode:206反转链表

方法一:迭代法

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
        ListNode prev = null;
        ListNode curr = head;

        while(curr != null){
            //记录后一个元素;指向前面
            ListNode temp = curr.next;
            curr.next = prev;

            //两个元素依次后移一步
            prev = curr;
            curr = temp;
        }
        return prev;
    }
}

可能一直理解两个数的对调容易,但是到这个链表牵扯到了三个数就容易迷惑一些;总之就是分两步:第一步是保存curr后面的元素,同时指向前面元素;第二步将curr和前面元素同时后移一步。

方法二:递归法

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
 class Solution {
    public ListNode reverseList(ListNode head) {
        if(head == null || head.next == null){
            return head;
        }

        ListNode newHead = reverseList(head.next);
        //两元素的指向调换
        head.next.next = head;
        head.next = null;

        return newHead;
    }
}

递归法的空间复杂度退化到O(N),因为要消耗系统调用栈。

相关推荐
AC赳赳老秦9 小时前
知识产权辅助:用 OpenClaw 批量生成专利交底书 / 软著申请材料,自动校验格式与内容合规性
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
WBluuue9 小时前
Codeforces 1093 Div2(ABCD1D2)
c++·算法
浅念-9 小时前
「一文吃透 BFS:从层序遍历到锯齿形、最大宽度、每层最大值」
数据结构·算法
汉克老师9 小时前
GESP5级C++考试语法知识(十三、贪心算法(一))
算法·贪心算法·海盗船·gesp5级·gesp五级·排队接水
梦想画家10 小时前
Apache AGE实战指南:从Cypher语法到核心图算法
算法·cypher·apache age
刀法如飞10 小时前
Go数组去重的20种实现方式,AI时代解决问题的不同思路
后端·算法·go
旖-旎11 小时前
深搜练习(N皇后)(10)
c++·算法·深度优先·力扣
Controller-Inversion12 小时前
322. 零钱兑换
算法
头发够用的程序员12 小时前
C++和Python面试经典算法汇总(一)
开发语言·c++·python·算法·容器·面试
淡海水12 小时前
【AI模型】模型量化技术详解
人工智能·算法·机器学习