题解 | #链表内指定区间反转#

链表内指定区间反转

https://www.nowcoder.com/practice/b58434e200a648c589ca2063f1faf58c?tpId=295&tqId=654&ru=/exam/company&qru=/ta/format-top101/question-ranking&sourceUrl=%2Fexam%2Fcompany

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 *   public ListNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param head ListNode类 
     * @param m int整型 
     * @param n int整型 
     * @return ListNode类
     */
    public ListNode reverseBetween (ListNode head, int m, int n) {
        // write code here
        //定义一个虚拟头结点比较好
        ListNode dummy = new ListNode(-1);
        dummy.next = head;
        //定义节点指针
        ListNode pre = dummy;
        ListNode cur = head;
        ListNode temp1 = null;//区间的前一节点
        ListNode temp2 = null;//区间的下一节点   
        ListNode temp4 = null;//区间的左端节点
        int i;

        if(m==n){
            return head;
        }
        for(i=0; i<m; i++){
            if(m==1){
                temp1 = pre;
            }else if(i==m-1){
                temp1 = pre;//保存区间的前一节点
            }  

            pre = pre.next;
            cur = cur.next;
            if(i==m-1){
                temp4 = pre;//保存区间的左端节点
                int k=0;
                while(k<=n-m-1){
                    ListNode temp = cur.next;
                    cur.next = pre;
                    pre = cur;
                    cur = temp;
                    k++;
                }
            }
            //pre为区间的右端节点
            temp2 = cur;//保存区间的下一节点      
        }
        temp1.next = pre;//区间的前一节点指向区间的右端节点
        temp4.next = cur;//区间的左端节点指向区间的下一节点

        return dummy.next;
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 10:39
一个证都没&nbsp;我能填什么
程序员小白条:别人有,你为什么没有,还是这个道理,社会就是比较,竞争,淘汰,你要安逸,那么就要做好淘汰的准备
点赞 评论 收藏
分享
嵐jlu:我是山川🐔里🐔🧱的,阿里系简历全过; 你这简历一看就还是半成品啊,没有荣誉经历奖项什么的吗?
投递阿里巴巴集团等公司10个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务