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

发布时间:2024-04-20 点击:117
输入两个链表,找出它们的第一个公共结点
1.两个单链表,有公共结点,那么必然,尾部公用
2.找出链表1的长度,找出链表2的长度,长的链表减去短的链表得出一个n值
3.长的链表先走n步,两个链表再同时移动
4.两个链表相交点就是第一个公共结点
list1 list2 len1 len2 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<?php class 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 } }

电脑卸载2345输入法后还有残留该如何彻底删除
软件著作权的登记流程
Enscape安装教程推荐 Enscape英文版弄成中文版方法
江苏宿迁移动高防云服务器
欧盟拟对Fitbit交易展开全面反垄断调查 除非谷歌让步
华云数据:“正向混合云”为企业打造上云之路
提交备案退回了提示所有人不对
域名丢失的常见原因有哪些?应该如何补救呢?