博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
删除链表的倒数第N个节点
阅读量:5897 次
发布时间:2019-06-19

本文共 716 字,大约阅读时间需要 2 分钟。

题目:

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

示例:

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

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

说明:

给定的 n 保证是有效的。

进阶:

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


之前我们说过 C 和 C++ 中的指针是个好东西 ,在解决这类问题很是方便 。然而 python 是没有这个概念的 ,包括链表也是模拟链表的相关操作 。刷题到这 ,小詹也得考虑总结下 python 中链表的相关操作了 。

思路一 :首先利用一次循环得到链表长度 ,之后根据题目输入的参数在指定位置进行删除操作 ,即要删除第 L-n+1 个节点 ,只需要将第 L-n 个节点的指针指向第 L-n+2 个节点即可跳过要删除的节点 。(在第 L-n+2 个节点存在的情况下 ,不存在即要删除倒数第一个节点 ,是个特例情况 。)

思路二:这里考虑用两个 ‘指针’ 进行操作 ,要删除倒数第 n 个节点 ,即与最后一个节点的间隔是固定的 (n-1)。这里先将两个指针同时指向头结点 ,然后第一个指针后移对应位置 ,使得两个指针间隔为 n-1 。之后两个指针同步后移 ,当先移动的指针指到最后的时候 ,第二个指针进行跳过删除操作 ,即可实现目的 。

image

说点题外话 ,leetcode 提交同一个代码会有一定的时间偏差 ,比如这个代码就在40-60 ms之间 ,导致得到的结果偏差很大 。小詹比较要脸 ,就放一个相对 beat 比较多的结果出来哈哈 。

image

原文发布时间为:2018-08-06

本文作者:小詹同学
本文来自云栖社区合作伙伴“”,了解相关信息可以关注“”

转载地址:http://maasx.baihongyu.com/

你可能感兴趣的文章
Tair数据迁移三步走
查看>>
XDEBUG+PHPSTORM 开发 调试
查看>>
AWS EC2服务器的HTTPS负载均衡器配置过程
查看>>
Matlab随笔之插值与拟合(上)
查看>>
技术干货 | K8S如何引入Volumes?
查看>>
[Leetcode] Reverse Bits 反转位
查看>>
SQL SERVER全面优化-------Expert for SQL Server 诊断系列
查看>>
[原创]Nginx反向代理及负载均衡
查看>>
zookeeper客户端管理工具
查看>>
Java序列化 ObjectInputStream源码解析
查看>>
程序员从BAT跳槽,却不会写二分查找,结果面试官却被喷,嗯?
查看>>
手帐的电子化研究
查看>>
sendEmail 带的参数
查看>>
运维工程师从入门到放弃必备书籍
查看>>
网络数据处理缓冲区和缓冲池实现
查看>>
有时候,解决问题比写代码更重要!
查看>>
NCalc 学习笔记 (一)
查看>>
第9天,异常处理
查看>>
scala入门之编写scala脚本
查看>>
Confluence 6 连接到一个 LDAP 目录
查看>>