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

链表内指定区间反转

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

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 * };
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @param m int整型 
 * @param n int整型 
 * @return ListNode类
 */
#include <stdlib.h>
/*法一: (虚拟头 + 头插法)反转链表 + 查询反转的前一个节点 + 终点结束 */
struct ListNode* reverseBetween(struct ListNode* head, int m, int n )
{
    if(m == n | head ==NULL)return head;
    //虚拟头:处理从头开始反转的情况
    struct ListNode* virtual_head = malloc(sizeof(struct ListNode));
    virtual_head->next = head;
    virtual_head->val =-1;

    //查询起点前一个节点
    struct ListNode* start=virtual_head;
    int num=1;
    //后移m-1次到反转前一个
    while (num < m) {
        start = start->next;
        num++;
    }

    //查询反转的尾节点、以及工作节点(要动的节点)
    struct ListNode* tail=start->next;
    struct ListNode* work=tail->next;

    for(int i=0;i<n-m;i++){
        //注意tail本身是不动的,主要把work头插到start后
        tail->next = work->next;
        work->next = start->next;
        start->next = work;
        //工作指针置位
        work = tail->next;
    }
    return virtual_head->next;
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
昨天 15:45
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务