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

链表内指定区间反转

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

全部评论

相关推荐

从24年初开学开始接触到前端,和实验室几个同学一起学习,可似乎我总比他们慢一步,每每学完一个地方,我掌握的程度好像都不比他们,第一次实验室的任务实战,我两眼一抹黑,完全不知道从何下手,而他们却是游刃有余,可我当时没有丧气,只有一个念头,既然学习能力不如他们,那我就拿更多的时间去学,于是我把打游戏,运动锻炼的时间也拿来学习。到了暑假,实验室一起做项目,为了可以更好的参与进去,于是我暑假开始留校和同学师哥一起做项目,每天早上九点多去实验室,晚上十点多回宿舍,校田径队的训练没有去,中间也只回家待了一周。到暑假结束开学之后,一位很优秀的师哥拿到了几个offer,我从他身上看到了希望,双非本科就业的希望...
offer求求哩:我的评价是认知低,建议多看书,认知低的一个表现是人生仿佛没考上大学就是进厂,考上了就是考研考公找工作。股市里有一个很有意思的故事,说的是当门口大妈都在谈论股票的时候,说明行情已经见顶了。当你的父母在某些事上没有成功却支持你说明事情可能已经不可靠了,但在某些事上反对你,说明这件事可能还有成功的可能。(仅个人观点)😆😆
点赞 评论 收藏
分享
头像
2024-12-19 18:11
英特尔_Software_engineer
下水道鼠鼠鼠鼠:男的能去当技师吗 好进吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务