ホームページ >バックエンド開発 >PHPチュートリアル >PHPで多次元配列ソートアルゴリズムを実装する方法は何ですか
今回は、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アプリケーションのコンテナ化とデプロイメントの使用方法の詳細な説明
PDOを使用したmysqlデータベースの追加、削除、変更、確認手順の詳細な説明
以上がPHPで多次元配列ソートアルゴリズムを実装する方法は何ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。