1. 本题知识点
链表
2. 题目描述
输入两个链表,找出它们的第一个公共结点。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的)

3. 解题思路
- 把两个链表的结点依次压入到两个栈中,这样两个链表的尾结点就位于两个栈的栈顶
- 比较两个栈顶的结点是否相同。如果相同,则把栈顶弹出继续比较下一个,直到找到最后一个相同的结点。
4. 代码
public class Solution {
public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
if (pHead1 == null || pHead2 == null) {
return null;
}
// 第一个公共结点
ListNode commonNode = null;
Deque<ListNode> stack1 = new LinkedList<>();
Deque<ListNode> stack2 = new LinkedList<>();
while (pHead1 != null) {
stack1.push(pHead1);
pHead1 = pHead1.next;
}
while (pHead2 != null) {
stack2.push(pHead2);
pHead2 = pHead2.next;
}
while (!stack1.isEmpty() && !stack2.isEmpty()) {
// 当两个栈顶元素相等时,即为公共结点
if (stack1.peek() == stack2.peek()) {
commonNode = stack1.peek();
stack1.pop();
stack2.pop();
continue;
}
// 当两个栈顶元素相等时,返回的就是第一个公共结点
return commonNode;
}
return commonNode;
}
}
本文介绍了一种通过使用栈来查找两个链表第一个公共节点的方法。首先将两个链表的节点依次压入两个栈中,然后比较并弹出相同的栈顶节点,直至找到最后一个相同的节点,即为首个公共节点。


被折叠的 条评论
为什么被折叠?



