leetcode算法206.反转链表

简介: 给你单链表的头节点 head ,如何反转链表,并返回反转后的链表?本文带大家解决这个问题。

一、leetcode算法



1、反转链表


1.1、题目


给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。


示例 1:


输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]


示例 2:


输入:head = [1,2]

输出:[2,1]


示例 3:


输入:head = []

输出:[]


1.2、思路


思路一:此题我们使用迭代的方式将每一个节点进行变化,首先要定义好当前节点,前一个节点,下一个节点都是谁,然后将他们进行一个值的转换。


1.3、答案


4.png


/**
 * 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 next = curr.next;
            //将当前节点指向前一个节点
            curr.next = prev;
            //将前一个节点定义为当前节点
            prev = curr;
            //将当前节点定义为下一个节点
            curr = next;
        }
        return prev;
    }
}


复杂度分析


时间复杂度:O(n),其中 n 是链表的长度。需要遍历链表一次。


空间复杂度:O(1)。


相关文章
|
11天前
|
算法
【优选算法专栏】专题九:链表--------两两交换链表中的节点
【优选算法专栏】专题九:链表--------两两交换链表中的节点
17 0
|
1月前
|
存储 算法 JavaScript
怎么刷算法,leetcode上有哪些经典题目
怎么刷算法,leetcode上有哪些经典题目
16 0
【移除链表元素】LeetCode第203题讲解
【移除链表元素】LeetCode第203题讲解
|
11天前
|
算法
算法系列--递归(一)--与链表有关(上)
算法系列--递归(一)--与链表有关
27 0
|
4天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
17 3
|
4天前
|
算法
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
9 3
|
4天前
|
算法
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
24 1
|
6天前
|
算法 DataX
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
二叉树(中)+Leetcode每日一题——“数据结构与算法”“剑指Offer55-I. 二叉树的深度”“100.相同的树”“965.单值二叉树”
|
8天前
【力扣】21. 合并两个有序链表
【力扣】21. 合并两个有序链表
|
11天前
|
算法
算法系列--链表刷题(二)(下)
算法系列--链表刷题(二)(下)
15 0

热门文章

最新文章