首页 > 语言 > PHP > 正文

PHP实现的多维数组排序算法分析

2024-05-05 00:02:24
字体:
来源:转载
供稿:网友

本文实例讲述了PHP实现的多维数组排序算法。分享给大家供大家参考,具体如下:

突然想起了一道面试题,把一个多维数组排序。

例:

<?php//有一个多维数组$a = array(  array('key1'=>940, 'key2'=>'blah'),  array('key1'=>23, 'key2'=>'this'),  array('key1'=>894, 'key2'=>'that'));//那么怎么对key1或者key2进行排序呢,这里就需要使用到usort($arr, 'myfunction')函数了,它的作用是对$arr使用我们自定义的方法进行排序,具体使用方法可以查看手册//1.对key1的值进行排序function asc_key1_sort($x, $y) {  //可以输出一下看看是怎么比较的  echo 'Iteration:'.$x['key1'].' vs '.$y['key1'];  if($x['key1'] > $y['key1']) {    echo 'true<br/>';    return true;  }elseif($x['key1'] < $y['key1']) {    echo 'false<br/>';    return false;  }else {    echo '0';    return 0;  }}//进行排序usort($a, 'asc_key1_sort');var_dump($a);//2.对key2字符进行排序function asc_key2_sort($x, $y) {  //可以使用strcasecmp()函数进行排序  echo 'Iteration:'.$x['key2'].' vs '.$y['key2'].'<br/>';  return strcasecmp($x['key2'], $y['key2']);}//进行排序usort($a, 'asc_key2_sort');var_dump($a);?>

运行结果:

Iteration:23 vs 940falseIteration:894 vs 23trueIteration:940 vs 23trueIteration:894 vs 940falsearray(3) { [0]=> array(2) { ["key1"]=> int(23) ["key2"]=> string(4) "this" } [1]=> array(2) { ["key1"]=> int(894) ["key2"]=> string(4) "that" } [2]=> array(2) { ["key1"]=> int(940) ["key2"]=> string(4) "blah" } } Iteration:that vs thisIteration:blah vs thatarray(3) { [0]=> array(2) { ["key1"]=> int(940) ["key2"]=> string(4) "blah" } [1]=> array(2) { ["key1"]=> int(894) ["key2"]=> string(4) "that" } [2]=> array(2) { ["key1"]=> int(23) ["key2"]=> string(4) "this" } } 

如果我的多维数组中也有key值呢?

<?php//有一个多维数组$a = array(  123 => array('key1'=>940, 'key2'=>'blah'),  349 => array('key1'=>23, 'key2'=>'this'),  43 => array('key1'=>894, 'key2'=>'that'));//那么怎么对key1或者key2进行排序呢,这里就需要使用到usort($arr, 'myfunction')函数了,它的作用是对$arr使用我们自定义的方法进行排序,具体使用方法可以查看手册//1.对key1的值进行排序function asc_key1_sort($x, $y) {  //可以输出一下看看是怎么比较的  echo 'Iteration:'.$x['key1'].' vs '.$y['key1'];  if($x['key1'] > $y['key1']) {    echo 'true<br/>';    return true;  }elseif($x['key1'] < $y['key1']) {    echo 'false<br/>';    return false;  }else {    echo '0';    return 0;  }}//进行排序usort($a, 'asc_key1_sort');var_dump($a);//2.对key2字符进行排序function asc_key2_sort($x, $y) {  //可以使用strcasecmp()函数进行排序  echo 'Iteration:'.$x['key2'].' vs '.$y['key2'].'<br/>';  return strcasecmp($x['key2'], $y['key2']);}//进行排序usort($a, 'asc_key2_sort');var_dump($a);?>

运行结果:

Iteration:23 vs 940falseIteration:894 vs 23trueIteration:940 vs 23trueIteration:894 vs 940falsearray(3) { [0]=> array(2) { ["key1"]=> int(23) ["key2"]=> string(4) "this" } [1]=> array(2) { ["key1"]=> int(894) ["key2"]=> string(4) "that" } [2]=> array(2) { ["key1"]=> int(940) ["key2"]=> string(4) "blah" } } Iteration:that vs thisIteration:blah vs thatarray(3) { [0]=> array(2) { ["key1"]=> int(940) ["key2"]=> string(4) "blah" } [1]=> array(2) { ["key1"]=> int(894) ["key2"]=> string(4) "that" } [2]=> array(2) { ["key1"]=> int(23) ["key2"]=> string(4) "this" } } 

这样的排序结果不会保留123,349,43。这时候只要把usort()换成uasort就好啦!

希望本文所述对大家PHP程序设计有所帮助。


注:相关教程知识阅读请移步到PHP教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选