이번에는 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<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 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" } }
다차원 배열에도 키 값이 있으면 어떻게 되나요?
<?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 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 애플리케이션 컨테이너화 및 배포 사용법에 대한 자세한 설명
PDO를 사용하여 mysql 데이터베이스를 추가, 삭제, 수정 및 확인하는 단계에 대한 자세한 설명
위 내용은 PHP에서 다차원 배열 정렬 알고리즘을 구현하는 방법은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!