快上网专注成都网站设计 成都网站制作 成都网站建设
成都网站建设公司服务热线:028-86922220

网站建设知识

十年网站开发经验 + 多家企业客户 + 靠谱的建站团队

量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决

怎么删除链表倒数的第n个结点-创新互联

这篇文章为大家分享有关怎么删除链表倒数的第n个结点的一道题目。文章介绍了删除链表结点的解题思路和解题方法,希望大家通过这篇文章能有所收获。

创新互联公司主营永善网站建设的网络公司,主营网站建设方案,app软件开发公司,永善h5小程序开发搭建,永善网站营销推广欢迎永善等地区企业咨询

怎么删除链表倒数的第n个结点

两趟扫描

两趟扫描的思想很简单,第一趟扫描确定长度,第二趟扫描定位到目标结点并进行删除操作.

public ListNode removeNthFromEnd(ListNode head, int n) 
{
   if(head == null || head.next == null)
     return null;
   ListNode head_copy = head;
   int length = 0;
   while(head != null)
   {
     head = head.next;
     ++length;
   }
   head = head_copy;
   ListNode before = head;
   int i = 0;
   for(;i

怎么删除链表倒数的第n个结点

一趟扫描

当然,来刷题的话不能就这样就算了,肯定得把它弄成一趟扫描,对吧?
两趟扫描的目的是获取长度再进行定位,因此,为了能一次定位,可以使用两个头指针,对于给定的n,先让第一个头指针访问n次,第二个头指针不动,当第一个头指针访问n次后,第一个头指针继续访问直到最后一个,第二个头指针与第一个头指针并行访问,这样,当第一个头指针访问到最后一个时,第二个头指针就指向倒数第N个节点.

public ListNode removeNthFromEnd(ListNode head, int n) {
   ListNode a = head;
   ListNode b = head;
   ListNode t = head;
   for(int i=0;i

总的来说这个只需要一趟扫描即可,针对只有两个结点或者一个结点的要判断一下.
怎么删除链表倒数的第n个结点

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


分享名称:怎么删除链表倒数的第n个结点-创新互联
URL分享:http://6mz.cn/article/cohdsh.html

免费获取网站建设与品牌策划方案报价

*主要业务范围包括:高端网站建设, 集团网站建设(网站建设网站制作)找网站建设公司就上快上网。
提交需求

    联系我们

    028-86922220
  • 手机:13518219792
  • 地址:成都市太升南路288号锦天国际A幢1002号
  • 24小时服务热线:400-028-6601

    网站建设服务

  • 网页设计
  • 网站制作
  • 网站开发

    网站推广服务

  • 营销网站建设
  • 百度快速排名
  • 整站网站推广

    网站运维服务

  • 基础维护
  • 网站改版
  • 网站维护

    FOLLOW US

  • 微信二维码

    微信二维码

Copyright © 2022 成都快上网科技有限公司 成都网站建设公司-选网站建设公司快上网!国内专业的网站制作公司!
All Rights Reserved 版权所有 蜀ICP备19037934号-11