题解 | #反转链表#

反转链表

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

class Solution:
    def ReverseList(selfhead: ListNode) -> ListNode:
        # write code here
        if head is None or head.next is None:
            return head
        new_head = None
        cur = head
        while cur != None:
            tmp = cur.next
            cur.next = new_head
            new_head = cur
            cur = tmp
        return new_head

解题思路记录:
1. 首先判断空链表或只有1个值的链表
2. 声明一个new链表 new_head初始化为None,声明一个cur初始化为head用于节点的移动
3. 使用tmp保存下一个节点的地址;
4. 当前节点的下一个节点指向新的链表(None为尾结点);
5.再将新链表的头节点指向当前节点,原链表的第一个节点实现翻转;
6.将当前节点指向原节点的下一个节点,重复上述步骤,实现所有节点的翻转。
#数据结构编程链表#
全部评论

相关推荐

不愿透露姓名的神秘牛友
10-09 16:39
已编辑
英俊的靓仔offer...:我感觉吧第二个寻迹小车的项目有点配不上你的学历了,写上去扣分了都可能对你来说,好歹是211硕士嘛,写在我这种二本混子的简历上还说得过去,个人观点哦,能再有个好点的项目应该会好很多,或者干脆不写第二个换个啥实习经历?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务