leetcode #92Reverse Linked List II

Reverse a linked list from position m to n. Do it in one-pass.

Note: 1 ≤ m ≤ n ≤ length of list.

Example:

Input: 1->2->3->4->5->NULL, m = 2, n = 4
Output: 1->4->3->2->5->NULL

反转需要三个指针,如此转换然后循环,每次连接结束后then 指向start。next
思路不难理解,只是自己写的时候有点想不起来,需要多看,理解
在这里插入图片描述

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode reverseBetween(ListNode head, int m, int n) {
        if(head == null)return head;
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        
        ListNode pre = dummy;
         for(int i = 0 ; i <m -1;i++){
             pre = pre.next;// 移动m -1 次
             
         }
        ListNode start = pre.next;
        ListNode then = start.next;
        for(int i = 0; i< n-m; i++){需要将start后面的n-m个点陆续反转
            
            start.next = then.next; // start 后面指向then 的后面
            then.next = pre.next; // then 的后面指向pre的后,相当于then插入pre和 pre。next之间
            pre.next = then;
            then = start.next;//完成一个元素的反转后,then指向下一个准备被反转(插入pre和pre.next之间)的节点            
            
        }
        return dummy.next;
    }
}```

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值