好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > PHP實現找出鏈表中環的入口節點

PHP實現找出鏈表中環的入口節點

熱門標簽:南寧高頻外呼回撥系統哪家好 長沙crm外呼系統業務 電話機器人危險嗎 400電話辦理福州市 離石地圖標注 專業電話機器人批發商 江蘇外呼電銷機器人報價 深圳外呼系統收費 400電話申請方法收費

本文實例講述了PHP實現找出鏈表中環的入口節點。分享給大家供大家參考,具體如下:

問題

一個鏈表中包含環,請找出該鏈表的環的入口結點。

解決思路

第一步,找環中相匯點。分別用p1,p2指向鏈表頭部,p1每次走一步,p2每次走二步,直到p1==p2找到在環中的相匯點。
第二步,找環的入口。接上步,當p1==p2時,p2所經過節點數為2x,p1所經過節點數為x,設環中有n個節點,p2比p1多走一圈有2x=n+x; n=x;可以看出p1實際走了一個環的步數,再讓p2指向鏈表頭部,p1位置不變,p1,p2每次走一步直到p1==p2; 此時p1指向環的入口。(還沒怎么懂)

實現代碼

?php
/*class ListNode{
  var $val;
  var $next = NULL;
  function __construct($x){
    $this->val = $x;
  }
}*/
function EntryNodeOfLoop($pHead)
{
  if($pHead == null || $pHead->next == null)
    return null;
  $p1 = $pHead;
  $p2 = $pHead;
  while($p2!=null  $p2->next!=null){
    $p1 = $p1->next;
    $p2 = $p2->next->next;
    if($p1 == $p2){
      $p2 = $pHead;
      while($p1!=$p2){
        $p1 = $p1->next;
        $p2 = $p2->next;
      }
      if($p1 == $p2)
        return $p1;
    }
  }
  return null;
}

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • PHP實現雙鏈表刪除與插入節點的方法示例
  • php實現單鏈表的實例代碼
  • PHP 雙鏈表(SplDoublyLinkedList)簡介和使用實例
  • PHP小教程之實現雙向鏈表
  • php鏈表用法實例分析
  • PHP中模擬鏈表和鏈表的基本操作示例
  • PHP實現的基于單向鏈表解決約瑟夫環問題示例
  • PHP實現單鏈表翻轉操作示例
  • php 數據結構之鏈表隊列
  • PHP基于雙向鏈表與排序操作實現的會員排名功能示例
  • PHP獲取鏈表中倒數第K個節點的方法

標簽:株洲 南京 白酒營銷 濱州 曲靖 南昌 興安盟 太原

巨人網絡通訊聲明:本文標題《PHP實現找出鏈表中環的入口節點》,本文關鍵詞  PHP,實現,找出,鏈表,中環,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現找出鏈表中環的入口節點》相關的同類信息!
  • 本頁收集關于PHP實現找出鏈表中環的入口節點的相關信息資訊供網民參考!
  • 推薦文章