PHP で分割統治法を使用して最近接点ペア問題を解決し、最適な解を得るにはどうすればよいですか?
分割統治法を使用して PHP の最近接点ペア問題を解決し、最適な解を得るにはどうすればよいですか?
最近接ペア問題とは、指定された平面上で 2 つの最も近い点のペアを見つけることを指します。この問題は計算幾何学では非常に一般的な問題であり、多くの解決策があります。一般的に使用される方法の 1 つは分割統治です。
分割統治法は、問題をより小さな部分問題に分割し、その部分問題を再帰的に解決することで元の問題を解決する方法です。最近点ペア問題では、分割統治法を使用して最適解を効率的に見つけることができます。
以下は、分割統治法を使用して最近接点ペア問題を解決する手順です。
- 点のセットを入力します。各点は (x, y)。
- x 座標に従ってポイント コレクションを並べ替えます。
- 点の数が 3 以下の場合は、総当たり法を直接使用して最近点ペア問題を解決します。つまり、2 点ごとに距離を計算し、最小距離を見つけます。
- 点セットを、それぞれ左と右と呼ばれる 2 つのほぼ等しいサブセットに分割します。
- 分割統治法を再帰的に呼び出して、左側と右側でそれぞれ最も近い点のペアを見つけます。 (left_min, left_max) および (right_min, right_max) として表されます。
- left_min と right_min の間の最小距離を持つ点のペアを取得し、それらの間の距離を計算し、min_ distance として記録します。
- 点コレクション内で、正中線からの x 座標距離が min_ distance 未満であるすべての点を検索し、それらを y 座標に従って並べ替えます。
- これらの点のうち、リニア スキャン法を使用して各点と後続の最大 6 点間の距離を計算し、最小距離を求めます。
- left_min と right_min の間の最小距離、および線形スキャンによって取得された最小距離を持つ点のペアを返します。
以下は、PHP 言語を使用して最近接点ペア問題を解決する分割統治法を実装するコード例です:
function closestPair($points) { $n = count($points); // 升序排序 usort($points, function($a, $b){ return $a['x'] - $b['x']; }); // 少于等于3个点直接暴力求解 if ($n <= 3) { return bruteForce($points); } // 分成两个子集合 $mid = floor($n / 2); $left = array_slice($points, 0, $mid); $right = array_slice($points, $mid); // 递归调用分治法 $leftPair = closestPair($left); $rightPair = closestPair($right); // 找到距离最小的点对 $delta = min($leftPair['distance'], $rightPair['distance']); $minPair = ($leftPair['distance'] < $rightPair['distance']) ? $leftPair : $rightPair; // 找到中线附近距离小于delta的点 $strip = []; foreach ($points as $point) { if (abs($point['x'] - $points[$mid]['x']) < $delta) { $strip[] = $point; } } // 按照y坐标排序 usort($strip, function($a, $b){ return $a['y'] - $b['y']; }); // 线性扫描 $stripPair = stripScan($strip, $delta); // 返回距离最小的点对 return ($minPair['distance'] < $stripPair['distance']) ? $minPair : $stripPair; } function bruteForce($points) { $n = count($points); $minDistance = PHP_INT_MAX; $minPair = []; for ($i = 0; $i < $n; $i++) { for ($j = $i+1; $j < $n; $j++) { $distance = distance($points[$i], $points[$j]); if ($distance < $minDistance) { $minDistance = $distance; $minPair = [$points[$i], $points[$j]]; } } } return [ 'distance' => $minDistance, 'pair' => $minPair ]; } function stripScan($strip, $delta) { $n = count($strip); $minDistance = $delta; $minPair = []; for ($i = 0; $i < $n-1; $i++) { for ($j = $i+1; $j < $n && ($strip[$j]['y'] - $strip[$i]['y']) < $minDistance; $j++) { $distance = distance($strip[$i], $strip[$j]); if ($distance < $minDistance) { $minDistance = $distance; $minPair = [$strip[$i], $strip[$j]]; } } } return [ 'distance' => $minDistance, 'pair' => $minPair ]; } function distance($a, $b) { return sqrt(pow(($b['x'] - $a['x']), 2) + pow(($b['y'] - $a['y']), 2)); }
上記は詳細な手順です。分割統治法を使用して最近接点ペア問題を解決する方法の詳細 コード例。問題をより小規模な部分問題に分割し、それらの部分問題を再帰的に解くことにより、最近点ペア問題を効率的に解き、最適解を得ることができます。合理的なアルゴリズムの設計と最適化を通じて、問題解決の効率とパフォーマンスを向上させることができます。
以上がPHP で分割統治法を使用して最近接点ペア問題を解決し、最適な解を得るにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









この記事では、PHP が行を CSV にフォーマットし、ファイル ポインタを書き込む方法について詳しく説明します。非常に実践的だと思いますので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。行を CSV にフォーマットし、ファイル ポインターに書き込む ステップ 1: ファイル ポインターを開く $file=fopen("path/to/file.csv","w"); ステップ 2: fputcsv( ) 関数を使用して行を CSV 文字列に変換するCSV文字列に変換します。この関数は次のパラメータを受け入れます。 $file: ファイル ポインタ $fields: 配列としての CSV フィールド $delimiter: フィールド区切り文字 (オプション) $enclosure: フィールド引用符 (

この記事では、PHP での現在の umask の変更について詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。現在の umask を変更する PHP の概要 umask は、新しく作成されたファイルとディレクトリのデフォルトのファイル権限を設定するために使用される PHP 関数です。引数を 1 つ受け取ります。これは、ブロックの許可を表す 8 進数です。たとえば、新しく作成されたファイルへの書き込み権限を禁止するには、002 を使用します。 umask を変更する方法 PHP で現在の umask を変更するには 2 つの方法があります。 umask() 関数を使用する: umask() 関数は現在の umask を直接変更します。その構文は次のとおりです。

この記事では、PHP で独自のファイル名を付けたファイルを作成する方法を詳しく解説します。編集者が非常に実践的だと考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。 PHP で一意のファイル名を持つファイルを作成する はじめに PHP で一意のファイル名を持つファイルを作成することは、ファイル システムを編成および管理するために不可欠です。一意のファイル名により、既存のファイルが上書きされず、特定のファイルの検索と取得が容易になります。このガイドでは、PHP で一意のファイル名を生成するいくつかの方法について説明します。方法 1: uniqid() 関数を使用する uniqid() 関数は、現在の時刻とマイクロ秒に基づいて一意の文字列を生成します。この文字列はファイル名の基礎として使用できます。

この記事では、ファイルの MD5 ハッシュを計算する PHP について詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。 PHP はファイルの MD5 ハッシュを計算します MD5 (MessageDigest5) は、任意の長さのメッセージを固定長の 128 ビットのハッシュ値に変換する一方向暗号化アルゴリズムです。ファイルの整合性の確保、データの信頼性の検証、デジタル署名の作成に広く使用されています。 PHP でのファイルの MD5 ハッシュの計算 PHP には、ファイルの MD5 ハッシュを計算するための複数の方法が用意されています: md5_file() 関数を使用します。 md5_file() 関数は、ファイルの MD5 ハッシュ値を直接計算し、32 文字の値を返します。

この記事では、PHP がどのようにしてキー値を反転した後に配列を返すのかについて詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。 PHP キー値フリップ 配列キー値フリップは、配列内のキーと値を交換して、元のキーを値として、元の値をキーとして持つ新しい配列を生成する配列に対する操作です。実装方法 PHP では、次の方法で配列のキーと値の反転を実行できます。 array_flip() 関数: array_flip() 関数は、キーと値の反転操作に特に使用されます。引数として配列を受け取り、キーと値が交換された新しい配列を返します。 $original_array=[

この記事では、PHP がどのようにファイルを指定の長さに切り詰めるのかについて詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。 PHP ファイルの切り詰めの概要 PHP の file_put_contents() 関数を使用すると、ファイルを指定した長さに切り詰めることができます。トランケーションとは、ファイルの末尾の一部を削除し、ファイルの長さを短くすることを意味します。構文 file_put_contents($filename,$data,SEEK_SET,$offset);$filename: 切り詰められるファイル パス。 $data: ファイルに書き込まれる空の文字列。 SEEK_SET: ファイルの先頭として指定されます

この記事では、PHP が配列内に指定されたキーが存在するかどうかを判断する方法について詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです。 PHP は、指定されたキーが配列内に存在するかどうかを判断します。 PHP では、指定されたキーが配列内に存在するかどうかを判断する方法が数多くあります。 1. isset() 関数を使用します: isset($array["key"]) この関数ブール値を返します。指定されたキーが存在する場合は true、存在しない場合は false。 2. array_key_exists() 関数を使用します: array_key_exists("key",$arr)

この記事では、前回の Mysql 操作で PHP から返されたエラー メッセージの数値エンコードについて詳しく説明します。編集者が非常に実用的であると考えたので、参考として共有します。この記事を読んで何かを得ることができれば幸いです. . PHP を使用して MySQL エラー情報を返す 数値エンコーディング はじめに mysql クエリを処理するときにエラーが発生する場合があります。これらのエラーを効果的に処理するには、エラー メッセージの数値エンコーディングを理解することが重要です。この記事では、php を使用して Mysql エラー メッセージの数値エンコーディングを取得する方法を説明します。エラー情報の数値エンコードを取得する方法 1. mysqli_errno() mysqli_errno() 関数は、現在の MySQL 接続の最新のエラー番号を返します。構文は次のとおりです: $erro
