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

数据结构-线性表(数组)-双指针-快慢指针 Offer22&19

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

数据结构-线性表(数组)-双指针-快慢指针 Offer22&19

  1. 剑指 Offer 22. 链表中倒数第k个节点

  2. 删除链表的倒数第 N 个结点

  • 思路
    对链表操作时,为了首尾节点操作与其他节点相同,需要添加头节点(哑节点dummy node)。
  1. 先确定链表的长度,然后找到要删除节点的前驱节点,进行删除。需要添加哑节点
  2. 双指针(快慢指针):快指针比慢指针快n+1个,因为慢指针要指向被删除元素的前驱节点,遍历整个链表,当快指针指向空时,慢指针正好指向被删除节点的前驱节点。初始化慢指针指向哑节点,快指针指向链表第一个节点
  • 代码
    第一个方法;
ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* dummy  = new ListNode(0,head);
        ListNode* low = dummy;
        ListNode* res = nullptr;
        int len = 0;;
        while(head){
            ++len;
            head = head->next;
        }
        for(int i = 0;i
            low = low->next;
        }
        low->next = low->next->next;
        res = dummy->next;
        return res;
    }

快慢指针;

ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* dummy  = new ListNode(0,head);
        ListNode* low = dummy;
        ListNode* fast = head;
        ListNode* res = nullptr;
        int i = 0;
        while(i
            ++i;
            fast = fast->next;
        }
        while(fast){
            low = low->next;
            fast = fast->next;
        }
        low->next = low->next->next;
        res = dummy->next;
        return res;
    }
  • 总结
    1:对列表操作为了首节点操作不失一般性,需要添加哑节点
    2:链表确定长度
    3:删除链表某个节点 p->next = p->next->next; 不一定非要找到指向被删除节点的下一个节点的指针p1使p->next = p1;
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/883492.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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