PHP二維去重算法的方法

導語:需求已搞定,只要遇到數組,我們第一個想到的除了現成的PHP方法之外,就是循環,不管是foreach還是for,下面就由小編爲大家介紹一下PHP二維去重算法的方法,歡迎大家閱讀!

PHP二維去重算法的方法

  需求

現在有下面一組二維數組:

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"

}

}

需要將處於第二維鍵名爲name,其值相同的數組的value合併,形成一個新的`數組。

比如上面代碼中的name爲fileds_510的兩個二維數組,就應該合併爲一個值爲足球,棒球的數組。

思路

提到數組,再PHP中我們首先想到了循環,那麼這裏顯然比較適合使用for循環處理,與冒泡排序相似,一個個比較,最好處理。

代碼

  代碼如下

$public_info = 數組;

for ($i=0;$i

for ($j=$i+1;$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"

}

}