【剑指Offer】快速刷题--总结心得

【反转链表】【easy]

前言

估计第一次写leetcode、牛客会遇到和我相同的一些疑问,在这里解答一下:

输入的数据类型是啥意思,定义写在哪里?

输入的数据类型的含义写在代码前方的框里,会写下对于这个类型的定义,包括你可以调用的方式

# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

如上方所示,说明你构建结点的方式是传入值x,并且结点存在两个变量,val/next,你只能访问这两个值。

答案

v1版本

class Solution:
    def ReverseList(self , head: ListNode) -> ListNode:
        if head is None or head.next is None:
            return head
        myhead = ListNode(head.val)
#         cur = myhead
        head = head.next
        while head:
            tmp = ListNode(head.val)
            tmp.next = myhead
            myhead = tmp
            head = head.next
        return myhead
评价
  • 判断增加head.next 是None的判断进行了提速
  • 存在的问题,中间存在一个临时变量,浪费了一些内存。
    优化:
    def ReverseList(self , head: ListNode) -> ListNode:
        if not head or not head.next:
            return head
        prev = None  #创建新链表的头结点
#         tmp = None
        while head:  
            tmp = head.next  #先把下一个结点存下来
            head.next = prev   #把当前结点放到新链表前面
            prev = head       #赋值新链表
            head = tmp        #处理下一个元素
        return prev
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值