在链表中若经常要删除表中最后一个,删除链表中倒数第k个节点

  在链表中若经常要删除表中最后一个,删除链表中倒数第k个节点

  BM9删除链表底部的第n个节点

  知识点链表双指针

  描述一个给定的链表,从链表的底部删除第n个节点,返回链表的头指针。

  例如,给定的链表是:

  删除链表的倒数第二个节点后,链表就变成了。

  数据范围:链表的长度,链表中任意节点的值满足要求:空间复杂度和时间复杂度。

  备注:产权保证书必须有效。

  示例1输入:

  {1,2},2副本返回值:

  {2}

  解决方案想法:

  和BM8一样,但是在寻找第k个节点的时候,只需要保存它的前任节点就可以了。具体代码见:

  #包含位/标准数据。h

  结构列表节点

  {

  int val

  struct ListNode * next

  ListNode(int x) : val(x),next(nullptr)

  {

  }

  ListNode()=默认值;

  };

  ListNode * removeNthFromEnd(ListNode * head,int k)

  {

  int I=0;

  自动节点=头;

  而(我k节点!=nullptr)

  {

  node=node-next;

  我;

  }

  如果(我知道)

  {

  返回nullptr

  }

  auto kth _ node=head

  ListNode * pre _ node=nullptr

  while(节点!=nullptr)

  {

  pre_node=第k _ node;

  第k个节点=第k个节点-下一个;

  node=node-next;

  }

  if (pre_node==nullptr)

  {

  head=head-next;

  }

  其他

  {

  pre_node- next=第k _ node-next;

  }

  回程头;

  }

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: