题目描述
- 暴力求解
一开始啥也不会就遍历。。。
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
if(headA==headB) return headA;
ListNode *p=headA;
bool flag=false;
while(p)
{
ListNode *s=headB;
while(s){
if(p==s) return s;
else s=s->next;
}
p=p->next;
}
return NULL;
}
};
- 模仿前面环形链表相遇问题,构建环
若两个链表长度相等,则在第一波走到相同结点时a=b跳出;
若两个链表长度不等,则创造环后类似快慢指针,总有相遇的时候
若没有交点,则a跳到B,b跳到A,交叉情况下会有在最后null处相遇,跳出循环
class Solution {
public:
ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
ListNode *a=headA;
ListNode *b=headB;
while(a!=b)
{
if (a!=nullptr) a=a->next;
else a=headB;
if(b!=nullptr) b=b->next;
else b=headA;
}
return a;
}
};
- 观察特征:有相同结点—相同值——>集合
先将一个链表中的数据加到集合中,再看另一个链表中的数据,若集合中存在,就是交点
一开始想用set,看了一下高级点还是hashset好一点(虽然还不太会用)
class Solution{
public:
ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
Set s=new HashSet();
ListNode a=headA;
ListNode b=headB;
while (a!=nullptr)
{
s.add(a);
a=a.next;
}
while(b!=nullptr){
if(s.contains(b)) return b;
b=b.next;
}
return b;
}
}