ホームページ >バックエンド開発 >PHPチュートリアル >[ヘルプ] PHP の 2 次元配列で特定の重複値を削除する問題

[ヘルプ] PHP の 2 次元配列で特定の重複値を削除する問題

WBOY
WBOYオリジナル
2016-06-23 14:25:561087ブラウズ

PHP 2 次元配列再帰値

元の配列:
$arr = array(
array('id' => 1,'name' => 'aaa','uid'=>1),
array('id' => 2,'name' => 'bbb','uid'=>2),
array('id' => 3,'name' => 'ccc', 'uid'=>3),
array('id' => 4,'name' => 'ddd','uid'=>4),
array('id' => 5, 'name' => 'ccc','uid'=>3)、
array('id' => 6,'name' => 'bbb','uid'=>2)、
array('id' => 7,'name' => 'bbb','uid'=>2),
array('id' => 8,'name' => 'fff', 'uid'=>6),
array('id' => 9,'name' => 'ccc','uid'=>3),
array('id' => 10, 'name' => 'bbb','uid'=>2)、
array('id' => 11,'name' => 'ddd','uid'=>4)、
array('id' => 12,'name' => 'eee','uid'=>5),
array('id' => 13,'name' => 'fff', 'uid'=>6),
);

問題の説明: $arr の ID 1,3,5,7,9 の値を取得したいのですが、 「name」と「uid」を繰り返すことはできません。たとえば、name==ccc は id==3 に対応しますが、name==ccc は id==5 に対応するため、id 5 の値は取得されず、次の id=6 の値が取得されます。 id=6 前の値と重複する値がある場合は、別の値を取得します。以下同様です。

ID 1、3、5、7、9 の値を取得したい場合、望ましい結果は次のようになります:
$arr_new = array(
array('id' => 1,'name' => ; 'aaa','uid'=>1),
array('id' => 3,'name' => 'ccc','uid'=>3),
array('id' = > 6,'名前' => 'bbb','uid'=>2),
配列('id' => 'fff','uid'=> ; 6),
);

ディスカッションへの返信 (解決策)

追加の説明: 取得したい ID 値はランダムに選択されます

これは、アルゴリズムの処理方法に問題があります。現在取得されているデータがすでに存在していることがわかったら、次のデータを削除します。このアルゴリズムの目的は、1 人が複数の投稿を投稿した場合、それを 1 つとしてカウントすることです。 、現在のクエリのデータ部分を走査するコードをコメントアウトするだけです

どうですか?

$arr = array( array('id' => 1,'name' => 'aaa','uid'=>1), array('id' => 2,'name' => 'bbb','uid'=>2), array('id' => 3,'name' => 'ccc','uid'=>3), array('id' => 4,'name' => 'ddd','uid'=>4), array('id' => 5,'name' => 'ccc','uid'=>3), array('id' => 6,'name' => 'bbb','uid'=>2), array('id' => 7,'name' => 'bbb','uid'=>2), array('id' => 8,'name' => 'fff','uid'=>6), array('id' => 9,'name' => 'ccc','uid'=>3), array('id' => 10,'name' => 'bbb','uid'=>2), array('id' => 11,'name' => 'ddd','uid'=>4), array('id' => 12,'name' => 'eee','uid'=>5), array('id' => 13,'name' => 'fff','uid'=>6), ); $id = array(1,3,5,7,9);foreach($arr as $v) $a[$v['id']] = $v;$t = array();foreach($id as $k) {  if(! in_array($a[$k]['name'], $t)) {    $res[] = $a[$k];    $t[] = $a[$k]['name'];  }else {    for($i=$k+1; $i<count($a); $i++)      if(! in_array($a[$i]['name'], $t)) {        $res[] = $a[$i];        $t[] = $a[$i]['name'];        break;      }  }}print_r($res);
Array
(
[0] => 配列
(
[id] => 1
[name] => aaa
[uid] => 1
)

[1] => ; 配列
(
[id] => 3
[name] => ccc
[uid] => 3
)

[2] => 配列
(
[id] => 6
[名前] => bbb [uid] => 2
)
[3] => 配列
[id] => 8
[名前] => fff
[uid] => ; 6
)
[4] => 配列
(
[id] => 11
[名前] => ddd
[uid] => 4
)

)


多谢版主

これはアルゴリズム処理の方法であり、現在取得されているデータが存在する場合は、次の条項を取得する必要があります。算法の目的これは、来用軟计人数的 一人人出版多张贴 また計算一 如果要解决 ただ遍在現在のデータ部分の代コード注释即可

嗯、

この問題の原型は:discuz论坛発行帖、有个抢楼的ただし、最終的にタワーの成功を確認した場合、繰り返しを中止し、そのタワーの次の層を成功に設定します。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。