寻求最优的计算数组方法,实在搞不出来了
我有两个数组分别是:
- PHP code
$arr1=array( array( 'id'=>1, 'pos'=>1 ), array( 'id'=>2, 'pos'=>2 ), array( 'id'=>3, 'pos'=>3 ), array( 'id'=>4, 'pos'=>4 ), array( 'id'=>5, 'pos'=>5 ), array( 'id'=>6, 'pos'=>6 ), ) $arr2=array( 'id'=>7, 'pos'=>4 )
首先查找$arr2的pos在$arr1中的所有数组的pos中的顺序位置,如果顺序位置一致则按照id倒序获取位置
如上面的代码则应该获取的结果为:$arr2位于$arr1的
- PHP code
array( 'id'=>4, 'pos'=>4 ),
之上
------解决方案--------------------
- PHP code
<?php $arr1=array( array( 'id'=>1, 'pos'=>1 ), array( 'id'=>2, 'pos'=>2 ), array( 'id'=>3, 'pos'=>3 ), array( 'id'=>4, 'pos'=>4 ), array( 'id'=>5, 'pos'=>5 ), array( 'id'=>6, 'pos'=>6 ), ); $arr2=array( 'id'=>7, 'pos'=>4 ); function array_insert($arr1, $arr2) { $index = 1; $insert = false; foreach($arr1 as $v) { if ($v['pos'] == $arr2['pos']) { if ($v['id'] < $arr2['id']) { array_splice($arr1, $index - 1, 0, array($arr2)); break; } else { $insert = true; } } else if ($insert) { break; } $index ++; } if ($insert) { array_splice($arr1, $index - 1, 0, array($arr2)); } return $arr1; } $arr1 = array_insert($arr1, $arr2); print_r($arr1); $arr2=array( 'id'=>3, 'pos'=>4 ); $arr1 = array_insert($arr1, $arr2); print_r($arr1); $arr2=array( 'id'=>5, 'pos'=>6 ); $arr1 = array_insert($arr1, $arr2); print_r($arr1); ?>
------解决方案--------------------
当
- PHP code
$arr1=array( array( 'id'=>1, 'pos'=>1 ), array( 'id'=>2, 'pos'=>2 ), array( 'id'=>3, 'pos'=>3 ), array( 'id'=>4, 'pos'=>5 ), array( 'id'=>5, 'pos'=>5 ), array( 'id'=>6, 'pos'=>6 ), ); $arr2=array( 'id'=>7, 'pos'=>4 );