【LeetCode-简单题】206. 反转链表

题目

在这里插入图片描述

题解一:双指针

 /**
     * 双指针
     * @param head
     * @return
     */
    public static ListNode reverseList1(ListNode head) {

        //申请节点,pre和 cur,pre指向null
        ListNode pre = null;
        ListNode cur = head;
        ListNode tmp = null;
        while(cur!=null) {
            //记录当前节点的下一个节点
            tmp = cur.next;
            //然后将当前节点指向pre
            cur.next = pre;
            //pre和cur节点都前进一位
            pre = cur;
            cur = tmp;
        }
        return pre;

    }

题解二:递归

 /**
     * 递归
     * @param head
     * @return
     */
    public static ListNode reverseList(ListNode head) {

        //递归结束条件
        if (head == null || head.next==null) {
             return head;
        }
        //直接找出最后一个节点
        ListNode lastNode = reverseList(head.next);
        //将最后一个节点指向倒数第二个节点
        head.next.next =  head;
        //断链
        head.next = null;
        return lastNode;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值