PHP 二维数组递归取值
原数组:补充说明:想获取的ID值,是随意选择的
这个是算法处理的方式有问题 他会遍历当前已经取的数据 然后如果查到已经有了 则取下一条 -- 这种算法的目的 是用来统计人数的 一个人发多张贴 也只算一个 如果要解决 只要把遍历当前查询的数据部分的代码注释即可
这个意思?
$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
多谢版主,就是这个意思。没想到回复这么快,非常感谢。
这个是算法处理的方式有问题 他会遍历当前已经取的数据 然后如果查到已经有了 则取下一条 -- 这种算法的目的 是用来统计人数的 一个人发多张贴 也只算一个 如果要解决 只要把遍历当前查询的数据部分的代码注释即可
嗯,
这个问题的原型是:discuz论坛发帖,有个抢楼的功能。设定抢楼的楼层之后,用户可以重复抢楼。但最终确定抢楼成功的用户时,想去掉重复的,并把设定该楼层的下一层为抢楼成功。