當前位置:才華齋>計算機>php語言>

PHP二維去重演算法的方法

php語言 閱讀(1.19W)

導語:需求已搞定,只要遇到陣列,我們第一個想到的除了現成的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"

}

}