标签:p2 ListNode 2022 链表 NC66 pHead2 null pHead1
描述
输入两个无环的单向链表,找出它们的第一个公共结点,如果没有公共节点则返回空。(注意因为传入数据是链表,所以错误测试数据的提示是用其他方式显示的,保证传入数据是正确的)
输入描述:
输入分为是3段,第一段是第一个链表的非公共部分,第二段是第二个链表的非公共部分,第三段是第一个链表和二个链表的公共部分。 后台会将这3个参数组装为两个链表,并将这两个链表对应的头节点传入到函数FindFirstCommonNode里面,用户得到的输入只有pHead1和pHead2。
返回值描述:
返回传入的pHead1和pHead2的第一个公共结点,后台会打印以该节点为头节点的链表。
方法1:使用Set存结点
import java.util.*; /* public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } }*/ public class Solution { public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) { ListNode p1 = pHead1, p2 = pHead2; Set<ListNode> set = new HashSet<>(); while(p1 != null) { set.add(p1); p1 = p1.next; } while(p2 != null) { if(set.contains(p2)) { return p2; } p2 = p2.next; } return null; } }
方法2:使用暴力,对p1的每个节点,均遍历一次p2
public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) { if (pHead1 == null || pHead2 == null) { return null; } ListNode firstNode = pHead2; for (; pHead1 != null; pHead1 = pHead1.next) { if (pHead2 == null) { pHead2 = firstNode; } for (; pHead2 != null; pHead2 = pHead2.next) { if (pHead1 == pHead2) { return pHead1; } } } return null; }
标签:p2,ListNode,2022,链表,NC66,pHead2,null,pHead1 来源: https://www.cnblogs.com/liujinhui/p/15858907.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。