面试ABC_数据结构和算法篇

算法篇

1. 如何判断一个单项链表有闭环, 并判断闭环的位置

  • 解析: 可以使用两个指针, 一个快指针, 一个慢指针, 如果有闭环, 则一定会相遇, 时间复杂度O(n);
  • 判断闭环位置: 当相遇的时候, 快指针静止不动, 慢指针继续前进, 直到遇到相同的值, 表示环的长度;
    注意: 判断环是否存在退出的条件
if(fast == null || fast.next() == null) {
	//不存在闭环
    return false;
}
if(fast == slow) {
	//存在闭环
	return true;
}

//判断闭环的位置
int index = linkedList.size() - sizeSlow;

2. 判断两个单项链表是否有交集, 并判断交集的位置(两个单项链表没有闭环)

  • 两个链表相交表示交点后面的值全部相同;
  • 方法1: 将第二个链表的开头接到第一个链表的结尾, 产生一个新的链表, 判断这个新的链表是否有闭环, 时间复杂度O(m+n);
  • 方法2: 遍历两个链表, 时间复杂度为O(m*n)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值