【算法题】获取单向链表中倒数第 N 个节点
2021/9/22 11:09:50
本文主要是介绍【算法题】获取单向链表中倒数第 N 个节点,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
思路:
单向链表中,获取正数第 N 个节点的方法,只需要从 head 向后前进 N 步即可。
代码:
In [1]: class Node: ...: def __init__(self, value, next=None): ...: self.value = value ...: self.next = next In [2]: def get(n, head): ...: node = head ...: for i in range(n): ...: node = node.next ...: return node.value # 定义一个链表 1 -> 2 -> 3 -> 4 -> 5 -> 6 -> None In [3]: node6 = Node(6) ...: node5 = Node(5, node6) ...: node4 = Node(4, node5) ...: node3 = Node(3, node4) ...: node2 = Node(2, node3) ...: node1 = Node(1, node2) In [4]: get(0, node1) Out[4]: 1 In [5]: get(1, node1) Out[5]: 2 In [6]: get(4, node1) Out[6]: 5
获取反向第 N 个节点。
因为单向链表无法获取当前节点之前的数据信息。所以1个指针无法完成这个工作,需要第二个指针,在第一个节点出发 N 步之后再出发,这样在第一个指针到达链表终点的时候, 第二个指针停留的位置即是倒数第 N 个节点。
下图展示了求倒数第三个节点的过程:
代码:
In [1]: class Node: ...: def __init__(self, value, next=None): ...: self.value = value ...: self.next = next # 定义一个链表 1 -> 2 -> 3 -> 4 -> 5 -> 6 -> None In [2]: node6 = Node(6) ...: node5 = Node(5, node6) ...: node4 = Node(4, node5) ...: node3 = Node(3, node4) ...: node2 = Node(2, node3) ...: node1 = Node(1, node2) In [3]: def get_reverse(n, head): ...: pnt_a = pnt_b = head ...: # 指针 a 先走 N 步 ...: try: ...: for i in range(n): ...: pnt_a = pnt_a.next ...: # 当链表长度小于 N 时, 返回 None ...: except AttributeError: ...: return None ...: # 两个指针开始同步前进,直到指针 a 到达终点 ...: while pnt_a: ...: pnt_a = pnt_a.next ...: pnt_b = pnt_b.next ...: return pnt_b.value In [4]: get_reverse(1, node1) Out[4]: 6 In [5]: get_reverse(3, node1) Out[5]: 4 In [6]: get_reverse(10, node1)
这篇关于【算法题】获取单向链表中倒数第 N 个节点的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API
- 2025-01-102025 蛇年,J 人直播带货内容审核团队必备的办公软件有哪 6 款?
- 2025-01-10高效运营背后的支柱:文档管理优化指南
- 2025-01-10年末压力山大?试试优化你的文档管理
- 2025-01-10跨部门协作中的进度追踪重要性解析
- 2025-01-10总结 JavaScript 中的变体函数调用方式
- 2025-01-10HR团队如何通过数据驱动提升管理效率?6个策略
- 2025-01-10WBS实战指南:如何一步步构建高效项目管理框架?