Loading [MathJax]/jax/input/TeX/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >LeetCode 206题 反转链表(Reverse Linked List)

LeetCode 206题 反转链表(Reverse Linked List)

作者头像
code随笔
发布于 2020-04-14 03:32:57
发布于 2020-04-14 03:32:57
39300
代码可运行
举报
文章被收录于专栏:code随笔的专栏code随笔的专栏
运行总次数:0
代码可运行

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

迭代解法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
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。

提交结果截图:

递归解法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
/**
 * 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变成空即可。 提交结果截图:

以上便是反转链表的迭代与递归两种解法。

欢迎关注

微信公众号:code随笔

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-01-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 code随笔 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
LinkedList - 206. Reverse Linked List
Reverse Linked List Reverse a singly linked list. Example: **Input:** 1->2->3->4->5->NULL **Output:*
ppxai
2020/09/23
3220
LeetCode 206. 反转链表
题目 反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题? 解题思路 记录一个数组值,然后再遍历重新赋值 class Solution: def reverseList(self, head: ListNode) -> ListNode: tempList = [] tempHead = head while tem
freesan44
2020/06/08
2160
LeetCode 206. 反转链表
来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/reverse-linked-list 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
Michael阿明
2022/11/26
2270
LeetCode 206. 反转链表
LeetCode 206. Reverse Linked List
206. Reverse Linked List Reverse a singly linked list. Example: Input: 1->2->3->4->5->NULL Output: 5->4->3->2->1->NULL 解法一: public ListNode reverseList(ListNode head) { if (head == null || head.next ==null) return head; ListNode pre = null; Lis
大学里的混子
2018/10/29
3310
LeetCode—链表反转
这是无量测试之道的第211篇原创 题目来源于 LeetCode 的第 206 题,难度为:easy。目前的通过率是71.7%。 题目描述 反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 题目解析 设置三个节点pre、cur、next (1)每次查看cur节点是否为NULL,如果是,则结束循环,获得结果 (2)如果cur节点不是为NULL,则先设置临时变量next为cur的下一个节点 (3)让cur的下一个节点变成指向pre,
Wu_Candy
2022/07/04
3020
LeetCode—链表反转
反转链表
在遍历列表时,将当前节点的 next 指针改为指向前一个元素。由于节点没有引用其上一个节点,因此必须事先存储其前一个元素。在更改引用之前,还需要另一个指针来存储下一个节点。不要忘记在最后返回新的头引用。
木子星兮
2020/07/16
6720
Leetcode 206. 反转链表
遍历链表,以 cur 表示当前节点,以 last 表示上一个节点,将 cur 的 next 指针指向 last 即可。
zhipingChen
2019/06/11
4570
Leetcode刷题 206. 反转链表 递归迭代两种方法实现
**链接**:https://leetcode-cn.com/problems/reverse-linked-list/
一只胡说八道的猴子
2020/10/09
5360
Leetcode刷题  206. 反转链表  递归迭代两种方法实现
LeetCode 每日一题206: 反转链表
按照题目的要求, 今天给出两个思路, 个人觉得迭代会比较容易思考出来, 先给出迭代的思路.
benny
2019/03/07
6220
LeetCode 每日一题206: 反转链表
图解精选 TOP 面试题 005.1 | 反转链表之递归求解
在上一篇《图解精选 TOP 面试题 005 | 反转链表之迭代求解》中,我们介绍了该题的迭代求解法,本篇再说说如何进行递归求解。
江不知
2019/12/19
5810
图解精选 TOP 面试题 005.1 | 反转链表之递归求解
前端最高频的算法题之一:反转链表
完整高频题库仓库地址:https://github.com/hzfe/awesome-interview
HZFEStudio
2021/10/02
5890
LeetCode 206:反转链表 Reverse Linked List
反转一个单链表。 Reverse a singly linked list. 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代
爱写bug
2019/07/22
3780
LeetCode每日一题-1:反转链表
链表一般都是用迭代或是递归法来解决,而且一般都是构造双指针、三指针,比如反转链表或是DP动态规划。
墨明棋妙27
2022/09/23
2140
链表问题-LeetCode 206、234、160(反转,回文,公共结点)
示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL
算法工程师之路
2019/11/04
3850
【python-leetcode206-翻转链表】反转链表
输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题?
西西嘛呦
2020/08/26
6700
【python-leetcode206-翻转链表】反转链表
每天一道leetcode206-反转链表
题目 leetcode206-反转链表 分类:链表 中文链接: https://leetcode-cn.com/problems/reverse-linked-list/ 英文链接: https://leetcode.com/problems/reverse-linked-list/ 题目详述 反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题? 题目详解 思路 反
乔戈里
2019/09/17
2880
图解精选 TOP 面试题 005 | 反转链表之迭代求解
链表反转在面试中非常常见,我也在面试中遇到过这道题。在本篇文章中我们先说说如何用迭代法求解该题。
江不知
2019/12/19
5520
图解精选 TOP 面试题 005 | 反转链表之迭代求解
LeetCode-206-反转链表
利用pre指针指向null,并利用cur指针存储head节点,当cur不为空的时候
benym
2022/07/14
1810
LeetCode-面试题24-反转链表
局部反转,将当前节点的后一个节点保存在temp指针里,改变cur指向前一个位置pre,然后向后移动一位pre和cur
benym
2022/07/14
2080
leecode刷题(22)-- 反转数组
再让 pre = key, key = last, last = last.next:
希希里之海
2019/03/19
4990
相关推荐
LinkedList - 206. Reverse Linked List
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验