编程之美_单链表面试题_结合3.4_3.6

本文详细探讨了单链表的操作,包括结点删除、倒数K个元素和中间元素的查找。接着讨论了单链表与环的问题,如环的判断、入口寻找和长度计算。此外,还阐述了单链表相交问题的判断及相交节点的确定,涵盖了有环和无环的情况。
摘要由CSDN通过智能技术生成

一、单链表结点的删除

0、删除单链表p指向的那个元素,(时间和空间复杂度尽量小)

二、单链表的存取

1、找出单链表的倒数第K个元素,(仅允许遍历一遍链表)

2、找出单链表的中间元素,(仅允许遍历一遍链表)

三、单链表与环的问题

3、判断单链表是否有环(6形状)?

4、如何找到环的入口?

5、如何知道环的长度?

6、带环链表的长度是多少?

四、单链表与相交、环的问题

7、如何知道两个单链表(无环)是否相交

8、如果两个单链表(无环)相交,如何知道它们相交的第一个节点是什么

9、如何知道两个单链表(有环)是否相交

10、如果两个单链表(有环)相交,如何知道它们相交的第一个节点是什么


~~~~~~~~~~~华丽的分割线~~~~~~~~~~~~~~

一、单链表结点的删除

0、删除单链表p指向的那个元素,(时间和空间复杂度尽量小)

思路:把q指向结点的值 赋给 p指向的结点,再把q指向结点删除

二、单链表的存取

1、找出单链表的倒数第K个元素,(仅允许遍历一遍链表)
思路:使用指针追赶的方法。定义两个指针fast和slow
  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值