栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

92. 反转链表 II

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

92. 反转链表 II

思路
局部反转链表:头插法
定义两个指针,分别称之为 g(guard 守卫) 和 p(point)。

    首先根据方法的参数 m 确定 g 和 p 的位置。将 g 移动到第一个要反转的节点的前面,将 p 移动到第一个要反转的节点的位置上。以 m=2,n=4为例。将 p 后面的元素删除,然后添加到 g 的后面。也即头插法。
    3、根据 m 和 n 重复步骤(2)
    4、返回 dummyHead.next
class Solution 
{
public:
    ListNode* reverseBetween(ListNode* head, int left, int right) 
    {
        ListNode* dummyNode = new ListNode(0);
        dummyNode->next = head;

        ListNode* g = dummyNode;//初始化指针
        ListNode* p = dummyNode->next;

        for(int i = 0; i < left - 1; ++i)//找到 局部反转链表 的左边界
        {
            g = g->next;//将 g 移动到第一个要反转的节点的前面
            p = p->next;//将 p 移动到第一个要反转的节点的位置上
        }

        for(int i = 0; i < right - left; ++i)//头插法插入节点
        {
            ListNode* removed = p->next;
            p->next = p->next->next;

            removed->next = g->next;
            g->next = removed;
        }

        return dummyNode->next;
    }
};
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/738658.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号