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

[PHP] 算法-找出两个链表的第一个公共结点的PHP实现的更多相关文章

  1. Java找出两个链表的第一个公共节点

    题目描述输入两个链表,找出它们的第一个公共结点. 我的思路:因为是链表,长度都是未知的,不能盲目的两个一起开始自增判断. 首先需要得到 L1的长度 和 L2的长度,让较长的那个先走 (length1- ...

  2. 编程算法 - 两个链表的第一个公共结点 代码(C)

    两个链表的第一个公共结点 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 输入两个链表, 找出它们的第一个公共结点. 计算链表的长度, 然后移动 ...

  3. php实现找两个链表的第一个公共结点(实例演示)

    php实现找两个链表的第一个公共结点(实例演示) 一.总结 因为是链表,第一个节点公共之后,后面所有的节点都公共了 画个图实例演示一下,会超清晰且简单 二.php实现找两个链表的第一个公共结点 题目描 ...

  4. 剑指Offer(三十六):两个链表的第一个公共结点

    剑指Offer(三十六):两个链表的第一个公共结点 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn.ne ...

  5. 九度OJ 1505 两个链表的第一个公共结点 【数据结构】

    题目地址:http://ac.jobdu.com/problem.php?pid=1505 题目描述: 输入两个链表,找出它们的第一个公共结点. 输入: 输入可能包含多个测试样例. 对于每个测试案例, ...

  6. C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告

    剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...

  7. 《剑指offer》第五十二题(两个链表的第一个公共结点)

    // 面试题52:两个链表的第一个公共结点 // 题目:输入两个链表,找出它们的第一个公共结点. #include <iostream> #include "List.h&quo ...

  8. 剑指Offer - 九度1505 - 两个链表的第一个公共结点

    剑指Offer - 九度1505 - 两个链表的第一个公共结点2013-11-24 20:09 题目描述: 输入两个链表,找出它们的第一个公共结点. 输入: 输入可能包含多个测试样例.对于每个测试案例 ...

  9. 【剑指offer】面试题 52. 两个链表的第一个公共结点

    面试题 52. 两个链表的第一个公共结点 NowCoder 题目描述 输入两个链表,找出它们的第一个公共结点. Java 实现 ListNode Class class ListNode { int ...

随机推荐

  1. C++ MFC棋牌类小游戏day5

    先整理一下之前的内容: 1.画了棋盘,把棋盘的每个点的状态都保存起来. 2.画棋子,分别用tiger类和people类画了棋子,并且保存了棋子的初始状态. 下面开始设计棋子的移动: 1.单机棋子,选中 ...

  2. Authorization Security for Mongodb

    To keep security for the mongodb server, we can create an authorized machanism. db.createUser( { use ...

  3. st-link调试和下载程序(待写)

    st-link调试只用三根线 GND SWCLK SWDIO

  4. 在windows 下使用eclipse进行编译和烧写

    eclipse IDE是一款开源的前端编程软件,它提供了编写,编译和调试ESP-IDF项目的图形集成开发环境. 首先在https://www.obeo.fr/en/eclipse-download?I ...

  5. java web中的异常处理

    1.集中处理 参考:https://blog.csdn.net/weililansehudiefei/article/details/73691294

  6. AFNetworking 3.0中调用[AFHTTPSessionManager manager]方法导致内存泄漏的解决办法

    在使用AFNetworking3.0框架,使用Instruments检查Leaks时,检测到1000多个内存泄漏的地方,定位到 [AFHTTPSessionManager manager] 语句中,几 ...

  7. UWP忽略短时间内重复触发的事件

    原链接:UWP忽略短时间内重复触发的事件 - 超威蓝火 做移动端开发的可能都会遇到这种需求,当用户点击一个按钮之后,由于没有异步,或者设备性能很差等等原因,程序卡住了.但是用户不知道是咋回事啊,就开始 ...

  8. grid布局学习二之子元素(项目)

    /* grid-column-start属性:左边框所在的垂直网格线 grid-column-end属性:右边框所在的垂直网格线 grid-row-start属性:上边框所在的水平网格线 grid-r ...

  9. fiddler电脑抓包和手机抓包

    概述 以前听别人说抓包抓包的,听起来很神秘高大上的样子,想入门又不知道从何学起.今天偶然在工作中遇到了以下2个需求: 改线上的代码,特别是PC端js代码. 写了一个移动端页面,由于跨域,改了host地 ...

  10. LinkedList 的源码分析

    LinkedList是基于双向链表数据结构来存储数据的,以下是对LinkedList  的 属性,构造器 ,add(E e),remove(index),get(Index),set(inde,e)进 ...