题解 | #反转链表#

反转链表

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#
全部评论

相关推荐

牛客633875330号:投不了,相当于空白简历,建议看看其他人简历上的项目和实习经历再说,。非科班无项目无实习,拿什么投计算机?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务