1

我有 2 个数组,第一个包含对象的值,第二个包含它们的 ID。
以这种形式:

$values[0] applies to $ids[0]
$values[1] applies to $ids[1]

我需要从最低到最高(值是整数)对第一个数组(使用 sort() )进行排序 - 这不是问题。问题是,当我用值对数组进行排序时,我会丢失该值的 ID。
我的问题是:如何做到这一点

If $values[0] turns to $values[5], automatically turn $ids[0] to $ids[5]


谢谢


更新:
$values 和 $ids 的内容:

$values[0] = 1.5;
$values[1] = 2.4;
$values[2] = 15.7;
$values[3] = 11.7;
$values[4] = 4.8;
$values[5] = 0.4;

$ids[0] = 1;
$ids[1] = 2;
$ids[2] = 3;
$ids[3] = 4;
$ids[4] = 5;
$ids[5] = 6;
4

3 回答 3

4

先组合数组,然后按键排序:

$newArr = array_combine($ids, $values);
ksort($newArr);
于 2012-05-29T17:24:22.717 回答
1

听起来您正在寻找array_combine()

例子

<?php
$ids = array(2, 1, 3); // IDs
$values = array(a, b, c); // Values
$array = array_combine($ids, $values); // Combine arrays as ID => Value
ksort($arrays); // Sort new array
print_r($array); // Echo array

输出

Array
(
 1 => b,
 2 => a,
 3 => c,
)
于 2012-05-29T17:23:59.177 回答
0

按照下面的代码......没有测试过......但它必须工作......容易理解......

<?php
$count = count($values);
for($i = 0; $i<$count; $i++)
{
   if($i == 0)
   {
      $sort1 = $values[$i];
      $sort2 = $ids[$i];
      $temp = 0;
   }
   if($sort1 > $values[$i])
   {
      $sort1 = $values[$i];
      $sort2 = $ids[$i];

      $temp_val = $values[$temp];
      $temp_id = $ids[$temp];

      $values['temp'] = $values[$i];
      $ids['temp'] = $ids[$i];

      $temp = $i;

      $values[$i] = $temp_val;
      $ids[$i] = $temp_id;  

   }
}
?>
于 2012-05-29T17:36:04.183 回答