扣丁学堂PHP培训

扣丁学堂简述PHP实现多维数组排序算法分析

2018-08-01  本文已影响1人  994d14631d16

扣丁学堂官网后台有学员留言说自己面试PHP开发开发工程师的时候遇到了一个面试题,把一个多维数组排序。今天扣丁学堂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
';

    return true;

  }elseif($x['key1'] < $y['key1']) {

    echo 'false
';

    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'].'
';

  return strcasecmp($x['key2'], $y['key2']);

}

//进行排序

usort($a, 'asc_key2_sort');

var_dump($a);

?>

运行结果:

Iteration:23 vs 940false

Iteration:894 vs 23true

Iteration:940 vs 23true

Iteration:894 vs 940false

array(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 this

Iteration:blah vs that

array(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值呢?

//有一个多维数组

$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
';

    return true;

  }elseif($x['key1'] < $y['key1']) {

    echo 'false
';

    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'].'
';

  return strcasecmp($x['key2'], $y['key2']);

}

//进行排序

usort($a, 'asc_key2_sort');

var_dump($a);

?>

运行结果:

Iteration:23 vs 940false

Iteration:894 vs 23true

Iteration:940 vs 23true

Iteration:894 vs 940false

array(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 this

Iteration:blah vs that

array(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实现多维数组排序算法分析,希望对小伙伴们能有所帮助,想要了解更多内容的小伙伴可以登录扣丁学堂官网咨询。扣丁学堂是专业的PHP培训机构,不仅有专业老师授课的PHP培训班让大家参加学习,还有与时俱进的课程体系以及大量的PHP在线视频供学员免费学习,想要学好PHP高薪就业的小伙伴不要再犹豫了,抓紧时间行动吧。

上一篇下一篇

猜你喜欢

热点阅读