ホームページ  >  記事  >  バックエンド開発  >  PHP は、リンク リスト内のリングのエントリ ノードの検索を実装します。

PHP は、リンク リスト内のリングのエントリ ノードの検索を実装します。

jacklove
jackloveオリジナル
2018-05-22 16:47:061372ブラウズ

この記事では、リンクリスト内のリングのエントリノードを見つけるためのPHP実装について説明します。

リンクリストにはリングが含まれています。リンクリストでリングのエントリノードを見つけてください。

解決策のアイデア

最初のステップは、リング内の交点を見つけることです。 p1 と p2 を使用して、p1==p2 がリング内の交点を見つけるまで、p1 は毎回 1 ステップ、p2 は毎回 2 ステップを実行します。

2 番目のステップは、リングへの入り口を見つけることです。前のステップからの続きで、p1==p2 の場合、p2 が通過するノードの数は 2x、p1 が通過するノードの数は x であり、リング内に n 個のノードがあり、p2 は p1 よりも 1 つ多く円を歩きます。 , so 2x=n+x; n =x; p1 が実際にリングのステップ数を取得し、p2 が p1 の位置を変更しないことがわかります。 p2 は p1==p2 まで一歩ずつ進みます。このとき、p1 はリングの入り口を指します。 (まだよく理解できていません)

実装コード

/*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中国語Webサイトを参照してください。

関連する推奨事項:

php nginxリアルタイム出力実装メソッド

PHPクラスSoapClientが見つからない処理メソッド

phpでmongoDBシングルトンモード操作クラスを実装する方法

以上がPHP は、リンク リスト内のリングのエントリ ノードの検索を実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。