多维数组排序有关问题
程序员文章站
2022-04-29 18:21:12
...
多维数组排序问题
有一数组:
想要排序的结果为:
即:$arr[$i][0] == $arr[$j][1] 那么$arr[$j]放在$arr[$i]后面
其实就是一个无限分类的一个排序,我试过多个循环来处理,不过有点麻烦,想用递归来实现,只实现了$arr[$i][0]=1的情况,请大家帮忙
分类比较少,就这么多了
------解决方案--------------------
这样写
有一数组:
- PHP code
想要排序的结果为:
- PHP code
即:$arr[$i][0] == $arr[$j][1] 那么$arr[$j]放在$arr[$i]后面
其实就是一个无限分类的一个排序,我试过多个循环来处理,不过有点麻烦,想用递归来实现,只实现了$arr[$i][0]=1的情况,请大家帮忙
分类比较少,就这么多了
------解决方案--------------------
这样写
- PHP code
$arr = array(array(1,0),array(2,0),array(3,0),array(4,0),array(5,1),array(6,1),array(7,5),array(8,2)); print_r(foo($arr)); function foo($ar, $p=0) { $r = array(); foreach($ar as $v) { if($v[1] == $p) { $r[] = $v; $r = array_merge($r, foo($ar, $v[0])); } } return $r; }相关文章
相关视频
上一篇: C++设计模式浅识外观模式