链表内指定区间反转

该博客主要讲解了如何使用Java实现指定范围内的双向链表反转。通过创建一个虚拟头节点简化操作,并使用迭代方式完成反转。代码中定义了一个ListNode类,包含整型值和next指针。Solution类的reverseBetween方法接收链表头节点、开始位置m和结束位置n,返回反转后的链表头节点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import java.util.*;

/*

* public class ListNode {

* int val;

* ListNode next = null;

* }

*/

public class Solution {

/**

*

* @param head ListNode类

* @param m int整型

* @param n int整型

* @return ListNode类

*/

public ListNode reverseBetween (ListNode head, int m, int n) {

if (head == null || n < m || n == 0) {

return head;

}

ListNode reverseNode = new ListNode(0);

reverseNode.next = head;

ListNode pre = reverseNode;

for (int i = 1; i < m; i++) {

pre = pre.next;

}

ListNode curr = pre.next;

while (n-- > m) {

ListNode temp = curr.next;

curr.next = temp.next;

temp.next = pre.next;

pre.next = temp;

}

return reverseNode.next;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值