千锋教育-做有情怀、有良心、有品质的职业教育机构

400-811-9990
手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

上海
  • 北京
  • 郑州
  • 武汉
  • 成都
  • 西安
  • 沈阳
  • 广州
  • 南京
  • 深圳
  • 大连
  • 青岛
  • 杭州
  • 重庆
当前位置:重庆千锋IT培训  >  技术干货  >  算法题(力扣)-删除链表的倒数第N个节点

算法题(力扣)-删除链表的倒数第N个节点

来源:千锋教育
发布人:qyf
时间: 2022-11-15 16:05:32

  题目描述

  给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。

  示例:

  给定一个链表: 1->2->3->4->5, 和 n = 2.

  当删除了倒数第二个节点后,链表变为 1->2->3->5.

  说明:

  给定的 n 保证是有效的。

  进阶:

  你能尝试使用一趟扫描实现吗?

  题目解析

  采取双重遍历肯定是可以解决问题的,但题目要求我们一次遍历解决问题,那我们的思路得发散一下。

  我们可以设想假设设定了双指针p和q的话,当q指向末尾的NULL,p与q之间相隔的元素个数为n时,那么删除掉p的下一个指针就完成了要求。

  设置虚拟节点dummyHead指向head

  设定双指针p和q,初始都指向虚拟节点dummyHead

  移动q,直到p与q之间相隔的元素个数为n

  同时移动p与q,直到q指向的为NULL

  将p的下一个节点指向下下个节点

  代码实现

1

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

猜你喜欢LIKE

java的输入语句—— Scanner类

2023-05-04

java数据库操作常识事务的四大特性

2023-05-04

DML数据操作之增加或删除数据

2023-05-04

最新文章NEW

socket是什么?有什么作用?

2023-05-04

Java常量定义是什么

2023-04-28

一分钟带你学多线程

2023-04-28

相关推荐HOT

更多>>

快速通道 更多>>

最新开班信息 更多>>

网友热搜 更多>>