欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

[PHP] 算法-找出两个链表的第一个公共结点的PHP实现

程序员文章站 2022-03-18 16:49:05
输入两个链表,找出它们的第一个公共结点 1.两个单链表,有公共结点,那么必然,尾部公用 2.找出链表1的长度,找出链表2的长度,长的链表减去短的链表得出一个n值 3.长的链表先走n步,两个链表再同时移动 4.两个链表相交点就是第一个公共结点 list1 list2 len1 len2 if len1... ......

 

输入两个链表,找出它们的第一个公共结点
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
  }
}