题解 | #链表内指定区间反转# 凑活看吧

链表内指定区间反转

https://www.nowcoder.com/practice/b58434e200a648c589ca2063f1faf58c

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(m==1&&n==1){
            return head;
        }

        // 找到m前一个位置处的节点
        ListNode mPre = head;
        //找到m前一个节点的位置
        for(int i = 0; i < m-2; i++){
            mPre = mPre.next;
        }
        //找到mnode
        ListNode mNode = null;
        if(m == 1){
            mNode = head;
        }else{
            mNode = mPre.next;
        }
        ListNode mNodeTmp = mNode;

        // 把m---n之间的反转
        ListNode pre = null; // pre是最后n的节点所在的位置
        ListNode next = null; // next是n节点后面一个节点的位置
        for(int j = 0; j <= n-m; j++){
            next = mNodeTmp.next;
            mNodeTmp.next = pre;
            pre = mNodeTmp;
            mNodeTmp = next;
        }
        if( m==1 ) {
            // 原来的首节点指向n节点的后一个节点
            mNode.next = next;
            //现在头结点变了
            return pre;
        }else {
            //处理开头结尾两个节点的指向
            mPre.next = pre;
            //开头m所对应的的节点指向next
            mNode.next = next;
            //此时头节点还是原来那个
            return head;
        }

    }
}

#算法题#
全部评论

相关推荐

球Offer上岸👑:可能是大环境太差了 太卷了 学历也很重要 hc也不是很多 所以很难
点赞 评论 收藏
分享
叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务