前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode - 反转链表

LeetCode - 反转链表

作者头像
晓痴
发布2019-09-26 15:49:08
3990
发布2019-09-26 15:49:08
举报
文章被收录于专栏:曌的晓痴曌的晓痴

LeetCode第206题,难度简单。

原题地址:https://leetcode-cn.com/problems/reverse-linked-list/)

题目描述

反转一个单链表。

示例:

代码语言:javascript
复制
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL

进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题?

解题思路:

先说递归的思路:

1. 首先肯定是判断递归的结束条件,当当前节点为null或者下一个节点为null时,就返回。

2. 然后是获取到当前节点的下一个节点,对其和之后的节点进行反转(递归调用)。

3. 获取到递归调用的结果之后,将下一节点的下一节点置位当前节点,并将当前节点的下一节点置位null,并返回。

然后将迭代的思路:

1. 首先定义前置节点和当前节点

2. 如果当前节点不为null,那就将前置和当前节点进行反转

3. 最后返回的是前置节点

中文官网题解:

https://leetcode-cn.com/problems/reverse-linked-list/solution/

个人题解:

代码语言:javascript
复制
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode reverseList(ListNode head) {
        if(null == head || null == head.next)
          return head;
      ListNode next = head.next; 
      ListNode result = reverseList(next); 
      next.next = head;
      head.next = null;
      return result;
    }
}


// 迭代
public ListNode reverseList(ListNode head) {
    ListNode prev = null;
    ListNode curr = head;
    while (curr != null) {
        ListNode nextTemp = curr.next;
        curr.next = prev;
        prev = curr;
        curr = nextTemp;
    }
    return prev;
}

结果:

正常水平,应该是相同的解法.

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

本文分享自 曌的晓痴 微信公众号,前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档