Leetcode 206题 反转链表(Reverse Linked List)Java语言求解

Posted nicaicai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode 206题 反转链表(Reverse Linked List)Java语言求解相关的知识,希望对你有一定的参考价值。

题目描述:
反转一个单链表。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

迭代解法

/**
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 pre = null;
        ListNode next = null;
        while(head!=null){
            next = head.next;
            head.next = pre;
            pre = head;
            head = next;
        }
        return pre;
    }
}

对代码进行解释:
1、准备两个空节pre和next点进行后续的操作,其中pre保存head之前的节点、next做临时变量;
2、如果head不空便进入循环体,转3;否则退出循环,返回pre,程序结束。
3、首先对临时变量next进行赋值,赋值为head的next值,以便操作过程中链表不断,转4;
4、为head的next赋值为pre(head的前一个元素),转5;
5、将pre赋值为当前的head的值,转6;
6、将head向后移动一位,赋值为next当前值,转2。

提交结果截图:
技术图片

技术图片

递归解法

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode reverseList(ListNode head) {
       //1.基本问题的解
        if(head == null || head.next == null){
           return head;
       }
       //2.将大问题分解成小问题
        ListNode reve = reverseList(head.next);
        //3.将小问题的解变成大问题的解
        head.next.next = head;
        head.next = null;
        return reve;
    }
}

对代码进行解释:
1、首先看递归头,也就是问题的基本问题:如果传入的是空或者只有一个节点,不用反转直接返回就可以;
2、将大问题分成小问题:就是反转head.next及其后面的节点组成的链表即可;
3、将小问题的解变成大问题的解:将原head.next的next指向head,原head的next变成空即可。
提交结果截图:
技术图片
技术图片
以上便是反转链表的迭代与递归两种解法。

欢迎关注

扫下方二维码即可关注:
技术图片

以上是关于Leetcode 206题 反转链表(Reverse Linked List)Java语言求解的主要内容,如果未能解决你的问题,请参考以下文章

Leetcode练习(Python):链表类:第206题:反转链表:反转一个单链表。

LeetCode Java刷题笔记—206. 反转链表

leetcode 206题,反转链表

精选力扣500题 第1题 LeetCode 206. 反转链表 c++详细题解

手绘漫画图解LeetCode之反转链表(LeetCode206题)

链表反转leetcode206