题解 | #反转链表#

反转链表

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

利用头插法,可以实现链表的反转

当链表不为空,并且链表不是只有head一个节点时 1、定义cur alt

2、将head置为空 alt 3、将cur用头插法的方式,插到head前面 alt 4、重新定义head,cur、curNext alt

public ListNode ReverseList (ListNode head) {
        // write code here
  //链表为空时
        if (head == null) {
            return null;
        }
  //链表只有一个节点时
        if (head.next == null) {
            return head;
        }
  //核心思想头插法
        ListNode cur = head.next;
        head.next = null;
        while (cur != null) {
            ListNode curNext = cur.next;
            cur.next = head;
            head = cur;
            cur = curNext;
        }
        return head;
    }
#反转链表go#
全部评论

相关推荐

不愿透露姓名的神秘牛友
11-21 11:29
已编辑
斯卡蒂味的鱼汤:知道你不会来数马,就不捞你😂最近数马疯狂扩招,招聘要求挺低的,你能力肯定够,应该就是因为太强了,知道你不会来才不捞你
投递腾讯云智研发等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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