题解 | #反转链表#

反转链表

https://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca

# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param head ListNode类 
# @return ListNode类
#
class Solution:
    def ReverseList(self , head: ListNode) -> ListNode:
        # write code here
        pre = None
        cur = head
        while cur:
            temp = cur.next
            cur.next = pre
            pre = cur 
            cur = temp
        
        return pre

使用两个指针pre和cur分别表示前一个节点和当前节点,同时借助一个临时变量temp用于存储当前节点原本的下一个节点(如果不保存,那么在cur.next=pre后就丢失了链表信息)。之后,一直for循环往后即可,最后返回pre指针。

全部评论

相关推荐

vegetable_more_exercise:1-1.5万,没错啊,最少是1人民币,在区间内
点赞 评论 收藏
分享
耀孝女:就是你排序挂了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务