leecode92 反转链表II

LeetCode92反转链表II题解

在这里插入图片描述

我的思路

这个比较简单,我们先找到这个需要反转的位置的前一个,以及找到反转位置的后一个。

把这两个中间的进行反转

然后拼接以下

public ListNode reverseBetween(ListNode head, int left, int right) {
    //定义一个头,这样就可以统一操作,这样如果left= 0的话,也可以直接操作了,不用单独讨论left=0没有前一个节点的清苦那个
    ListNode pre = new ListNode(0,head);
    ListNode ans = pre;
    for (int i = 0; i < left - 1; i++) {
        pre = pre.next; //这个是左边的头
    }
    ListNode last = pre;
    for(int  i = left-1;i<=right;i++){
        last =last.next; //这个是右边的尾
    }

    ListNode temp = pre.next;
    head = temp;
    ListNode pre_temp =last;
    while(head!=last){
        temp = head.next;
        head.next = pre_temp;
        pre_temp = head;
        head = temp;
    }
    pre.next = pre_temp;
    return ans.next;
}

注意

需要注意的是这个ans不能够一开始指向pre.next,最后返回ans,只能够一开始指向pre,最后返回ans.next,因为如果一开始指向这个pre.next的话,那么这个ans和head指向的对象是一个。当后续对head进行修改的时候,这个ans也会发生变化。

灵神的思路

灵神思路和我的类似,区别在于灵神并没有找这个last节点,而是发现遍历之后temp指向的就是last节点的位置。

在这里插入图片描述

class Solution {
    public ListNode reverseBetween(ListNode head, int left, int right) {
        ListNode dummy = new ListNode(0, head);
        ListNode p0 = dummy;
        for (int i = 0; i < left - 1; i++) {
            p0 = p0.next;
        }

        ListNode pre = null;
        ListNode cur = p0.next;
        for (int i = 0; i < right - left + 1; i++) {
            ListNode nxt = cur.next;
            cur.next = pre; // 每次循环只修改一个 next,方便大家理解
            pre = cur;
            cur = nxt;
        }

        // 见视频
        p0.next.next = cur;
        p0.next = pre;
        return dummy.next;
    }
}

作者:灵茶山艾府
链接:https://leetcode.cn/problems/reverse-linked-list-ii/solutions/1992226/you-xie-cuo-liao-yi-ge-shi-pin-jiang-tou-teqq/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值