单链表及循环链表已知问题整理

1. 如何快速查找到一个单链表的中间位置

方法:通过快慢指针来查找中间位置。设置两个指针,快指针和慢指针,慢指针每次移动一次,快指针每次移动两次。当快指针出现null,则到达链表末尾。此时慢指针的数据就是中间值。

2. 一个单链表,输出此链表的倒数第k各节点。

方法一:遍历单链表,求出链表长度N。(求出K点的位置P)N-K=P,再次从头开始遍历至P点。
方法二:
1.定义两个指针p1,p2分别指向链表的头部。
2.P1前进值K点,则p1,p2相距K点。
3.p1,p2开始同时前进,每次前进一个节点。
4.当p1到达末尾,p2所在的位置就是K点的位置。

3. 怎么判断链表是否是循环链表

方法一:通过快慢指针来检测链表是否是循环链表。设置两个指针,快指针和慢指针,慢指针每次移动一次,快指针每次移动两次,如果快指针追赶上慢指针,则为循环链表,否则不是循环链表。
方法二:借助hasmap判断是否经历过此点。
在这里插入图片描述

4. 求有环单链表的环长

在环上相遇后,记录第一次相遇点为Pos,之后指针slow继续每次走1步,fast每次走2步。在下次相遇的时候fast比slow正好又多走了一圈,也就是多走的距离等于环长。
  设从第一次相遇到第二次相遇,设slow走了len步,则fast走了2len步,相遇时多走了一圈:
    环长=2
len-len。

5.求有环单链表的环连接点位置

第一次碰撞点Pos到连接点Join的距离=头指针到连接点Join的距离,因此,分别从第一次碰撞点Pos、头指针head开始走,相遇的那个点就是连接点。
在这里插入图片描述
  在环上相遇后,记录第一次相遇点为Pos,连接点为Join,假设头结点到连接点的长度为LenA,连接点到第一次相遇点的长度为x,环长为R。
    第一次相遇时,slow走的长度 S = LenA + x;
    第一次相遇时,fast走的长度 2S = LenA + nR + x;
    所以可以知道,LenA + x = n
R;  LenA = n*R -x;

6.求有环单链表的链表长

上述2中求出了环的长度;3中求出了连接点的位置,就可以求出头结点到连接点的长度。两者相加就是链表的长度。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值