输入两个链表,找出它们的第一个公共结点
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交易展开全面反垄断调查 除非谷歌让步华云数据:“正向混合云”为企业打造上云之路提交备案退回了提示所有人不对域名丢失的常见原因有哪些?应该如何补救呢?