• LeetCode206.反转链表


    题目

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

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

    输入:head = [1,2]
    输出:[2,1]
    示例 3:

    输入:head = []
    输出:[]

    提示:
    链表中节点的数目范围是 [0, 5000]
    -5000 <= Node.val <= 5000

    来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/reverse-linked-list 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路

    采用迭代方式完成反转

    1->2->3->4->5
    设置两个变量: 存储上一个节点 prev,存储当前节点 curr
    直到当前节点为空时结束循环:  
       循环内逻辑: 定义next保存当前节点的下一个节点
                   当前节点指向上一个节点
                   上一个节点变成当前节点
                   当前节点变成下一个节点    
    最后返回赋值为最后一个节点的变量prev即可
    

    采用递归方式完成反转

    当前节点为空或已经指向到最后一个节点时结束递归,返回当前节点。
    否则将下一个节点往下递,
    归的过程:将当前节点的下一个节点指向当前节点,将当前节点的指针指向空
    返回新链表头节点
    

    代码

    // 迭代方式 时间复杂度为O(n) n为链表长度 空间复杂度为 O(1)
    func reverseList(head *ListNode) *ListNode {
    // 存储上一个节点,初始化为空
    var prev *ListNode
    // 当前节点
    curr := head
    for curr != nil {
    	// 存储下一个节点
    	next := curr.Next
    	// 将当前节点指向上一个节点
    	curr.Next = prev
    	// 将当前节点作为上一个节点
    	prev = curr
    	// 将下一个节点作为当前节点
    	curr = next
    
    	// 赋值简写 curr.Next,prev,curr = prev,curr,curr.Next
    }
    // 返回结果为上一个节点变量,因为当前节点变量指向为空
    return prev
    }
    
    // 递归方式 时间复杂度 O(n) 空间复杂度 O(n)
    func reverseList2(head *ListNode) *ListNode {
    // 终止条件,当前节点为空或指向到最后一个节点
    if head == nil || head.Next == nil{
    	return head
    }
    // 递
    newHead := reverseList2(head.Next)
    // 归 将当前节点的下一个节点指向当前节点
    head.Next.Next = head
    // 将当前节点指向空
    head.Next = nil
    return newHead
    }
  • 相关阅读:
    轻量级Spring定时任务(Spring-task)
    Mysql语句优化建议
    python时间日期处理
    subprocess
    Tkinter初体验
    java基础
    java JVM
    NFV
    java加载properties文件的六种方法总结
    悲观锁和乐观锁的区别
  • 原文地址:https://www.cnblogs.com/hzpeng/p/15030070.html
Copyright © 2020-2023  润新知