>백엔드 개발 >PHP 튜토리얼 >PHP의 배열 다중 정렬 정렬 원리에 대한 자세한 예

PHP의 배열 다중 정렬 정렬 원리에 대한 자세한 예

WBOY
WBOY원래의
2016-07-25 08:52:161040검색
  1. $data[] = array('volume' => 67, 'edition' => 2);
  2. $data[] = array('volume' => 86, 'edition' => 1);
  3. $data[] = array('volume' => 85, 'edition' => 6);
  4. $data[] = array('volume' => 98, 'edition' => 2);
  5. $data[] = array('volume' => 86, 'edition' => 6);
  6. $data[] = array('volume' => 67, 'edition' => 7);
  7. ?>
复制代码

例2:

  1. $a = array(1,2,3);
  2. $b = array(3);
  3. // 将数据根据 volume 降序排列,根据 edition 升序排列
  4. // 把 $data 作为最后一个参数,以通用键排序
  5. array_multisort($a, $b, $data);//数组一维个数不同
  6. var_dump( $data);
  7. ?>
复制代码

以上测试代码提示数组不一致的个数。 Warning: array_multisort(): Array sizes are inconsistent in G:wwwtestindex.php on line15

再看一个例子:

  1. $data[] = array('volume' => 67, 'edition' => 2);
  2. $data[] = array('volume' => 86, 'edition' => 1);
  3. $data[] = array('volume' => 85, 'edition' => 6);
  4. $data[] = array('volume' => 98, 'edition' => 2);
  5. $data[] = array('volume' => 86, 'edition' => 6);
  6. $data[] = array('volume' => 67, 'edition' => 7, 3, 4,4);//二维个数不同
  7. ?>
复制代码

代码2:

  1. $a = array(11,2,3,4,5,6);
  2. $b = array(3,3,3,3,3,3);
  3. //从结果中看到对应11的array(67,7,3,4,4)按相同顺序出现了;
  4. // 将数据根据 volume 降序排列,根据 edition 升序排列
  5. // 把 $data 作为最后一个参数,以通用键排序
  6. array_multisort($a, $b, $data);
  7. var_dump( $a,$data);
  8. ?>
复制代码

从上面的结果可以得知: 数组参数必须有相同的一维个数; 然后每个数组的对应位置(注意不是相同key,而是从自然位置对应着,如$a(1=>4),对应$b(99=>4) 的4,因为它们的位置都是第一个,而非key(1,99)的对应关系),对应位置中的值就像穿在一个个互相平等竹杆上一样,穿在上面的其中一个值需要调整位置时,就会导致同一"竹杆"上的其它值出现垂直移动。

类:

$a $b $c 4=>7 8=>10 '999' => 0 9=>9 0=>1 999=>9 0=> 2 9=> 3 9999=>7

如果出现按$a的7与9对换,也就会带动$b的10与1对换 $c的0与9对换。 所以关系就像上面的三个数组,同色的在同一"阵线上",其中一个换,大家要一起换位置。

就介绍这些吧,希望有助于大家理解 multisort 数组排序的用法。

>>> 更多内容,请查看 php数组排序方法大全



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.