久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP實(shí)現(xiàn)的多維數(shù)組排序算法分析

這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了PHP實(shí)現(xiàn)的多維數(shù)組排序算法。分享給大家供大家參考,具體如下:

突然想起了一道面試題,把一個(gè)多維數(shù)組排序。

例:

<?php
//有一個(gè)多維數(shù)組
$a = array(
  array('key1'=>940, 'key2'=>'blah'),
  array('key1'=>23, 'key2'=>'this'),
  array('key1'=>894, 'key2'=>'that')
);
//那么怎么對(duì)key1或者key2進(jìn)行排序呢,這里就需要使用到usort($arr, 'myfunction')函數(shù)了,它的作用是對(duì)$arr使用我們自定義的方法進(jìn)行排序,具體使用方法可以查看手冊(cè)
//1.對(duì)key1的值進(jìn)行排序
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;
  }
}
//進(jìn)行排序
usort($a, 'asc_key1_sort');
var_dump($a);
//2.對(duì)key2字符進(jìn)行排序
function asc_key2_sort($x, $y) {
  //可以使用strcasecmp()函數(shù)進(jìn)行排序
  echo 'Iteration:'.$x['key2'].' vs '.$y['key2'].'<br/>';
  return strcasecmp($x['key2'], $y['key2']);
}
//進(jìn)行排序
usort($a, 'asc_key2_sort');
var_dump($a);
?>

運(yùn)行結(jié)果:

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" } } 

如果我的多維數(shù)組中也有key值呢?

<?php
//有一個(gè)多維數(shù)組
$a = array(
  123 => array('key1'=>940, 'key2'=>'blah'),
  349 => array('key1'=>23, 'key2'=>'this'),
  43 => array('key1'=>894, 'key2'=>'that')
);
//那么怎么對(duì)key1或者key2進(jìn)行排序呢,這里就需要使用到usort($arr, 'myfunction')函數(shù)了,它的作用是對(duì)$arr使用我們自定義的方法進(jìn)行排序,具體使用方法可以查看手冊(cè)
//1.對(duì)key1的值進(jìn)行排序
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;
  }
}
//進(jìn)行排序
usort($a, 'asc_key1_sort');
var_dump($a);
//2.對(duì)key2字符進(jìn)行排序
function asc_key2_sort($x, $y) {
  //可以使用strcasecmp()函數(shù)進(jìn)行排序
  echo 'Iteration:'.$x['key2'].' vs '.$y['key2'].'<br/>';
  return strcasecmp($x['key2'], $y['key2']);
}
//進(jìn)行排序
usort($a, 'asc_key2_sort');
var_dump($a);
?>

運(yùn)行結(jié)果:

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" } } 

這樣的排序結(jié)果不會(huì)保留123,349,43。這時(shí)候只要把usort()換成uasort就好啦!

PS:這里再為大家推薦一款關(guān)于排序的演示工具供大家參考:

在線動(dòng)畫(huà)演示插入/選擇/冒泡/歸并/希爾/快速排序算法過(guò)程工具:
http://tools.jb51.net/aideddesign/paixu_ys

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:

  • PHP 多維數(shù)組的排序問(wèn)題 根據(jù)二維數(shù)組中某個(gè)項(xiàng)排序
  • array_multisort實(shí)現(xiàn)PHP多維數(shù)組排序示例講解
  • PHP 多維數(shù)組排序(usort,uasort)
  • php比較多維數(shù)組中值的大小排序?qū)崿F(xiàn)代碼
  • php簡(jiǎn)單實(shí)現(xiàn)多維數(shù)組排序的方法
  • php中多維數(shù)組按指定value排序的實(shí)現(xiàn)代碼
  • PHP 多維數(shù)組排序?qū)崿F(xiàn)代碼
  • php關(guān)于array_multisort多維數(shù)組排序的使用說(shuō)明
  • php中array_multisort對(duì)多維數(shù)組排序的方法
  • PHP編程實(shí)現(xiàn)多維數(shù)組按照某個(gè)鍵值排序的方法小結(jié)【2種方法】
  • php實(shí)現(xiàn)多維數(shù)組排序的方法示例
【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開(kāi)發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
這篇文章主要為大家詳細(xì)介紹了搜索附近的人PHP實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
主站蜘蛛池模板: 国产精品久久久久久亚洲影视 | 一区二区三区视频在线观看 | 欧美乱强伦| 国产在线视频一区二区 | 男女久久久 | 日本高潮视频 | www.亚洲一区 | av手机在线观看 | 午夜在线视频观看 | 快播少女爱欢乐 | 国产精品一区二区av | 国产三级精品视频 | 久久精品国产视频 | 可以看的毛片 | 手机看片日韩 | 日b免费视频 | a毛片大片| 成人免费激情视频 | 日韩精品| 欧美一区二区在线 | 色综合久久天天综合网 | 免费av观看 | 中文字幕一区在线观看 | 亚洲欧美网站 | 久久综合激情 | 成人免费网站在线观看 | 午夜a级片 | 激情婷婷 | 日日夜夜精品 | 黄色a一级 | 国产天天操 | 国产成人精品毛片 | 成人动漫免费观看 | 免费a在线观看 | 成人午夜毛片 | 亚洲精选在线观看 | 成人在线视频播放 | 一区二区三区视频 | 在线国产小视频 | 青青草手机视频 | 国语对白做受欧美 |