算法篇
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)