剑指offer:(37)时间效率和空间效率的平衡 :两个链表的第一个公共结点

输入两个链表,找出它们的第一个公共结点。

思路一:因为如果两个链表有公共节点的话,则他们的尾部是一样的,用两个栈来存两个链表的节点,开始弹出的值是相同的,弹到不同的时候,就截至,其下一节点就是所求第一个公共节点。

//最快捷的方法
	public static ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
		ListNode p1 = pHead1;
		ListNode p2 = pHead2;
		while(p1!=p2){
			p1 = (p1==null)?pHead2:p1.next;
			p2 = (p2==null)?pHead1:p2.next;
		}
		return p1;
	}


package cn.com.jianzhioffer;

import java.util.Stack;

public class Solution37 {
	public static class ListNode {
		int val;
		ListNode next = null;

		ListNode(int val) {
			this.val = val;
		}

		public boolean equals(ListNode pNode1, ListNode pNode2) {
			if (pNode1.val == pNode2.val)
				return true;
			return false;
		}
	}

	public static ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {
		if (pHead1 == null || pHead2 == null)
			return null;
		Stack<ListNode> stack1 = new Stack<ListNode>();
		Stack<ListNode> stack2 = new Stack<ListNode>();
		ListNode pNode1 = pHead1;
		ListNode pNode2 = pHead2;
		while (pNode1 != null) {
			stack1.push(pNode1);
			pNode1 = pNode1.next;
		}
		while (pNode2 != null) {
			stack2.push(pNode2);
			pNode2 = pNode2.next;
		}
		pNode1 = stack1.pop();
		pNode2 = stack2.pop();
		while (pNode1.equals(pNode2) && (!stack1.empty()) && (!stack2.empty())) {
			pNode1 = stack1.pop();
			pNode2 = stack2.pop();
		}
		if (stack1.empty() || stack2.empty()) {
			return pNode1;
		} else {
			return pNode1.next;
		}

	}

	public static void main(String[] args) {
		ListNode pHead1 = new ListNode(1);
		ListNode pNode2 = new ListNode(2);
		ListNode pNode3 = new ListNode(3);

		pHead1.next = pNode2;
		pNode2.next = pNode3;

		ListNode pHead2 = new ListNode(4);
		pHead2.next = pNode2;

		System.out.println(FindFirstCommonNode(pHead1, pHead2).val);

	}

}



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值