题解 | #两个链表的第一个公共结点#

两个链表的第一个公共结点

https://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46

/*
struct ListNode {
	int val;
	struct ListNode *next;
	ListNode(int x) :
			val(x), next(NULL) {
	}
};*/
#include <iostream>
class Solution {
public:
    ListNode* FindFirstCommonNode( ListNode* pHead1, ListNode* pHead2) {
		int m1=0,m2=0;
		ListNode* p1=pHead1,* p2=pHead2;
	  //m1,m2分别记录两个链表的长度
		while(p1!=nullptr)
		{
			++m1;
			p1=p1->next;
		}
		while(p2!=nullptr)
		{
			++m2;
			p2=p2->next;
		}
	  //如果有空链表返回空
		if(m1==0||m2==0)
		{
			return nullptr;
		}
		else 
		{
			int n=abs(m1-m2);
			ListNode* Longp,* Shortp;
			m1>m2?(Longp=pHead1,Shortp=pHead2):(Longp=pHead2,Shortp=pHead1);//如果希望三目运算符运行多条指令,应该使用?(多条指令):(多条指令)的形式,圆括号不可省略。
			while(n)//先将开始结点对其
			{
				Longp=Longp->next;
				--n;  
			}
			while(Longp!=nullptr&&Shortp!=nullptr)//同时向后移动,查看是否到相同结点
			{
				if(Longp==Shortp)
				{
					
					return Longp;
				}
				cout<<Longp->val<<" "<<Shortp->val<<endl;
				Longp=Longp->next;
				Shortp=Shortp->next;
			}
			return nullptr;

		}
        
    }
};

全部评论

相关推荐

合不合适,我自己说了才算
码农索隆:hr:“真执着啊,来我公司当法人吧”
点赞 评论 收藏
分享
不要停下啊:大二打开牛客,你有机会开卷了,卷起来,去找课程学习,在牛客上看看大家面试笔试都需要会什么,岗位有什么需求就去学什么,努力的人就一定会有收获,这句话从来都经得起考验,像我现在大三了啥也不会,被迫强行考研,炼狱难度开局,啥也不会,找工作没希望了,考研有丝丝机会
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务