最適化された方法で 2 つの配列を交互にマージする
プログラミングの分野では、2 つの配列を効率的にマージするのは一般的なタスクです。連結は簡単ですが、場合によっては、両方の配列の値をインターリーブして交互にマージする必要がある場合があります。単純なループ ソリューションは利用可能ですが、パフォーマンスの観点からは最適ではない可能性があります。
頻繁にマージ操作を必要とする時間に敏感なアプリケーションの場合は、より効率的なアプローチが望ましいです。 PHP は、この最適化を実現する組み込みソリューションを提供します。
$count = count($a1); for ($i = 0; $i < $count; $i++) { $newArray[] = $a1[$i]; $newArray[] = $b1[$i]; }
このメソッドは、結果の配列のサイズを事前に計算し、両方の入力配列から交互に値を割り当て、最適化されたマージ操作を実現します。ベンチマークでは、特に何千ものマージ操作を実行する場合に、この手法が単純なループ アプローチを上回ることが示されています。
// Pre-counting array size $a1 = array(0, 1, 2); $a2 = array(3, 4, 5); $start = microtime(TRUE); for ($t = 0; $t < 100000; $t++) { $newArray = array(); $count = count($a1); for ($i = 0; $i < $count; $i++) { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; } } echo round(microtime(TRUE) - $start, 2); // 0.6 // Without pre-counting $a1 = array(0, 1, 2); $a2 = array(3, 4, 5); $start = microtime(TRUE); for ($t = 0; $t < 100000; $t++) { $newArray = array(); for ($i = 0; $i < count($a1); $i++) { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; } } echo round(microtime(TRUE) - $start, 2); // 0.85
結論として、事前にカウントされた配列サイズを使用する組み込みメソッドは、時間の面で大幅なパフォーマンス上の利点を提供します。頻繁な配列マージ操作を必要とする機密性の高いアプリケーション。
以上がPHP で交互配列のマージを最適化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。