PHP学习之查找两个链表的第一个公共结点

PHP学习之查找两个链表的第一个公共结点

内容导读

收集整理的这篇技术教程文章主要介绍了PHP学习之查找两个链表的第一个公共结点,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2626字,纯文字阅读大概需要4分钟

内容图文

本篇文章小编将带大家学习用PHP实现查找两个链表的第一个公共结点,具有一定的参考价值,感兴趣的朋友可以看看,希望对你有所帮助。

输入两个链表,找出它们的第一个公共结点
1.两个单链表,有公共结点,那么必然,尾部公用
2.找出链表1的长度,找出链表2的长度,长的链表减去短的链表得出一个n值
3.长的链表先走n步,两个链表再同时移动
4.两个链表相交点就是第一个公共结点

list1 list2len1 len2if len1 > len2

n=len1-len2

for i=0;i<n;i++



list1=list1->nextelse

n=len2-len1

for i=0;i<n;i++



list2=list2->nextwhile list1!=null

if list1==list2



 return list1

list1=list1->next

list2=list2->nextreturn null
<?phpclass Node{



public $data;



public $next;



public function __construct($data=""){







$this->data=$data;



}
 }//构造一个链表$linkList1=new Node();$linkList1->next=null;$temp=$linkList1;$node1=new Node(1);$temp->next=$node1;$temp=$node1;$node2=new Node(2);$temp->next=$node2;$temp=$node2;$node3=new Node(3);$temp->next=$node3;$temp=$node3;$node4=new Node(4);$temp->next=$node4;$temp=$node4;$node5=new Node(5);$temp->next=$node5;$node5->next=null;//构造一个和上面有公共结点的链表$linkList2=new Node();$linkList2->next=null;$temp=$linkList2;$node7=new Node(7);$temp->next=$node7;$node7->next=$node4;//链向上面链表的第四个结点var_dump($linkList1);var_dump($linkList2);$commonNode=FindFirstCommonNode($linkList1,$linkList2);var_dump($commonNode);//找第一个公共结点function FindFirstCommonNode($pHead1, $pHead2){



//链表1的长度



$len1=0;



$temp=$pHead1->next;



while($temp!=null){







$temp=$temp->next;







$len1++;



}



//链表2的长度



$len2=0;



$temp=$pHead2->next;



while($temp!=null){







$temp=$temp->next;







$len2++;



}



$list1=$pHead1->next;



$list2=$pHead2->next;



//长的链表先走n步



if($len1 > $len2){







$n=$len1-$len2;







for($i=0;$i<$n;$i++){











$list1=$list1->next;







}



}else{







$n=$len2-$len1;







for($i=0;$i<$n;$i++){











$list2=$list2->next;







}



}



//两个链表长度一致,同时走,第一个相同的点就是第一个公共结点



while($list1!=null){







if($list1==$list2){











return $list1;







}







$list1=$list1->next;







$list2=$list2->next;



}



return null;}
object(Node)#1 (2) {
["data"]=>
string(0) ""
["next"]=>
object(Node)#2 (2) {

["data"]=>

int(1)

["next"]=>

object(Node)#3 (2) {


["data"]=>


int(2)


["next"]=>


object(Node)#4 (2) {



["data"]=>



int(3)



["next"]=>



object(Node)#5 (2) {




["data"]=>




int(4)




["next"]=>




object(Node)#6 (2) {





["data"]=>





int(5)





["next"]=>





NULL




}



}


}

}
}}object(Node)#7 (2) {
["data"]=>
string(0) ""
["next"]=>
object(Node)#8 (2) {

["data"]=>

int(7)

["next"]=>

object(Node)#5 (2) {


["data"]=>


int(4)


["next"]=>


object(Node)#6 (2) {



["data"]=>



int(5)



["next"]=>



NULL


}

}
}}object(Node)#5 (2) {
["data"]=>
int(4)
["next"]=>
object(Node)#6 (2) {

["data"]=>

int(5)

["next"]=>

NULL
}}

相关教程:PHP视频教程

以上就是PHP学习之查找两个链表的第一个公共结点的详细内容,更多请关注Gxl网其它相关文章!

内容总结

以上是为您收集整理的PHP学习之查找两个链表的第一个公共结点全部内容,希望文章能够帮你解决PHP学习之查找两个链表的第一个公共结点所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。

内容备注

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。


本文关键词:

联系我们

在线咨询:点击这里给我发消息

邮件:w420220301@qq.com