各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案各类知识收集,PHP技术分享与解决方案

Str Tom,为分享PHP技术和解决方案,贡献一份自己的力量!
收藏本站(不迷路),每天更新好文章!
当前位置:首页 > CMS教程 > PHP

php如何实现找出两个链表的第一个公共结点(代码实例)

管理员 2023-09-05
PHP
127

php如何实现找出两个链表的第一个公共结点(代码实例)

内容导读

收集整理的这篇技术教程文章主要介绍了php如何实现找出两个链表的第一个公共结点(代码实例),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2737字,纯文字阅读大概需要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如何实现输出链表倒数第k个结点(代码实例)

以上就是php如何实现找出两个链表的第一个公共结点(代码实例)的详细内容,更多请关注Gxl网其它相关文章!

内容总结

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

内容备注

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

扫码关注

qrcode

QQ交谈

回顶部