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

链表内指定区间反转

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;
    }
}

全部评论

相关推荐

10-28 11:04
已编辑
美团_后端实习生(实习员工)
一个2人:我说几个点吧,你的实习经历写的让人觉得毫无含金量,你没有挖掘你需求里的 亮点, 让人觉得你不仅打杂还摆烂。然后你的简历太长了🤣你这个实习经历看完,估计没几个人愿意接着看下去, sdk, 索引这种东西单拎出来说太顶真了兄弟,好好优化下简历吧
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务