ホームページ >バックエンド開発 >PHPチュートリアル >PHP の 2 次元配列重複排除アルゴリズム
要件
現在、次の 2 次元配列のセットがあります:
array(8) { [0]=> array(2) { ["name"]=> string(4) "name" ["value"]=> string(6) "青叶" } [1]=> array(2) { ["name"]=> string(5) "phone" ["value"]=> string(11) "13812341234" } [2]=> array(2) { ["name"]=> string(12) "fileds_507[]" ["value"]=> string(12) "我是青叶" } [3]=> array(2) { ["name"]=> string(12) "fileds_508[]" ["value"]=> string(6) "合肥" } [4]=> array(2) { ["name"]=> string(12) "fileds_509[]" ["value"]=> string(3) "男" } [5]=> array(2) { ["name"]=> string(12) "fileds_510[]" ["value"]=> string(6) "足球" } [6]=> array(2) { ["name"]=> string(12) "fileds_510[]" ["value"]=> string(6) "棒球" } [7]=> array(2) { ["name"]=> string(12) "fileds_511[]" ["value"]=> string(16) "2016-12-15T11:15" } }
新しい配列を形成するには、2 次元のキー名 name と同じ値を持つ配列の値をマージする必要があります。
たとえば、上記のコード内のfields_510という名前の2つの2次元配列は、サッカーと野球の値を含む配列にマージされる必要があります。
考え方
PHPでは配列というとまずループを考えるので、ここではバブルソートに似たforループ処理を使用する方が明らかに適しています。1つずつ比較するのが最善です。
コード
コードは次のとおりです:
$public_info = 数组; for ($i=0;$i<count($public_info);$i++) { for ($j=$i+1;$j<count($public_info);$j++) { if ($public_info[$j]['name'] == $public_info[$i]['name']) { $public_info[$i]['value'] .= ',' . $public_info[$j]['value']; unset($public_info[$j]); } } }
実行結果:
array(7) { [0]=> array(2) { ["name"]=> string(4) "name" ["value"]=> string(6) "青叶" } [1]=> array(2) { ["name"]=> string(5) "phone" ["value"]=> string(11) "13812341234" } [2]=> array(2) { ["name"]=> string(12) "fileds_507[]" ["value"]=> string(12) "我是青叶" } [3]=> array(2) { ["name"]=> string(12) "fileds_508[]" ["value"]=> string(6) "合肥" } [4]=> array(2) { ["name"]=> string(12) "fileds_509[]" ["value"]=> string(3) "男" } [5]=> array(2) { ["name"]=> string(12) "fileds_510[]" ["value"]=> string(13) "足球,棒球" } [7]=> array(2) { ["name"]=> string(12) "fileds_511[]" ["value"]=> string(16) "2016-12-15T11:15" } }
概要
要件は満たされています。配列に遭遇する限り、既製のもの以外に最初に考えられるものです。 PHP メソッドは foreach であっても for であってもループです。上記の例は、私がプロジェクトで処理したカスタム フォームを編集する短いプロセスです。皆さんの参考になれば幸いです。
PHP の 2 次元配列重複排除アルゴリズムに関連するその他の記事については、PHP 中国語 Web サイトに注目してください。