數(shù)組相關(guān)處理函數(shù)2

冒泡排序法

<?php

$arr=array(0,1,23,34,4,5,56,7,8,69);
//從小到大
function mysort(&$arr){
  $len=count($arr);
  for($i=0;$i<$len-1;$i++){
    for($j=0;$j<$len-$i-1;$j++){
      if($arr[$j]<$arr[$j+1]){
        $tmp=$arr[$j];
        $arr[$j]=$arr[$j+1];
        $arr[$j+1]=$tmp;
      }
    }
  }
}
mysort($arr);
print_r($arr);
//從大到小
function mysort(&$arr){
  $len=count($arr);
  for($i=0;$i<$len-1;$i++){
    for($j=0;$j<$len-$i-1;$j++){
      if($arr[$j]>$arr[$j+1]){
        $tmp=$arr[$j];
        $arr[$j]=$arr[$j+1];
        $arr[$j+1]=$tmp;
      }
    }
  }
}
mysort($arr);
print_r($arr);

快速排序法

<?php
//快速排序法,原理為二叉樹(shù)
$arr=array(20,18,40,65,78,4,66,34,87,98,5,64,45);

function qsort($arr){
  if(!is_array($arr) || empty($arr))
    return array();
  //獲取數(shù)組的長(zhǎng)度
  $len=count($arr);
  //如果數(shù)組中只有一個(gè)元素,直接返回這個(gè)數(shù)組
  if($len <=1)
    return $arr;
  $key[0] =$arr[0];
  $left =array();
  $right=array();

  for($i =1;$i<$len;$i++){
    if($arr[$i] <=$key[0]){
      $left[]=$arr[$i];
    }else{
      $right[]=$arr[$i];
    }
  }
  $left=qsort($left);
  $right=qsort($right);

  return array_merge($left,$key,$right);
}

print_r($arr);
echo '<br>';

print_r(qsort($arr));

數(shù)組排序函數(shù)

<?php

// sort -- 對(duì)數(shù)組排序(升序)
// rsort -- 對(duì)數(shù)組逆向排序(降序)
// ksort -- 對(duì)數(shù)組按照鍵名排序
// krsort -- 對(duì)數(shù)組按照鍵名逆向排序
// asort -- 對(duì)數(shù)組進(jìn)行排序并保持索引關(guān)系(關(guān)聯(lián)數(shù)組排序)
// arsort --  對(duì)數(shù)組進(jìn)行逆向排序并保持索引關(guān)系
// natsort --  用“自然排序”算法對(duì)數(shù)組排序
// natcasesort --  用“自然排序”算法對(duì)數(shù)組進(jìn)行不區(qū)分大小寫(xiě)字母的排序
// usort --  使用用戶(hù)自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序
// uasort --  使用用戶(hù)自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序并保持索引關(guān)聯(lián)
// uksort --  使用用戶(hù)自定義的比較函數(shù)對(duì)數(shù)組中的鍵名進(jìn)行排序
// array_multisort -- 對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序

//sort排序可以對(duì)數(shù)字咖楣、字母進(jìn)行排序,原數(shù)組有鍵名排序后不保存
//sort 數(shù)字升序排序
$arr=array(1,3,4,2,6,7,5,9,8,0);

print_r($arr);
echo '<br>';

sort($arr);

print_r($arr);
echo '<br>';

//rsort 數(shù)字降序排序

rsort($arr);

print_r($arr);
echo '<br>';

//sort 字母升序排序
$arra=array("one","two","three","four","five");

print_r($arra);
echo '<br>';

sort($arra);

print_r($arra);
echo '<br>';
//sort 字母降序排序

rsort($arra);

print_r($arra);
echo '<br>';

ksort 對(duì)數(shù)組按照鍵名排序

krsort 鍵名降序排序

asort 對(duì)數(shù)組進(jìn)行排序并保持索引關(guān)系

arsort 降序排序

<?php

//ksort 對(duì)數(shù)組按照鍵名排序
//ksort 鍵名升序排序
$lamp =array(1=>"Linux",10=>"Apache",35=>"Mysql",20=>"PHP");

print_r($lamp);
echo '<br>';

ksort($lamp);
print_r($lamp);
echo '<br>';

//krsort 鍵名降序排序
krsort($lamp);
print_r($lamp);
echo '<br>';
//asort 對(duì)數(shù)組進(jìn)行排序并保持索引關(guān)系
//asort 升序排序
$la =array("l"=>"Linux","m"=>"Apache","a"=>"Mysql","p"=>"PHP");
print_r($la);
echo '<br>';

asort($la);
print_r($la);
echo '<br>';
//arsort 降序排序
arsort($la);
print_r($la);
echo '<br>';

natsort 用自然排序算法對(duì)數(shù)組排序

natcasesort 用自然排序算法對(duì)數(shù)組進(jìn)行不區(qū)分大小寫(xiě)字母的排序

usort 使用用戶(hù)自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序

uasort可以保留原有鍵值名

<?php
//natsort 用自然排序算法對(duì)數(shù)組排序 如果有大寫(xiě)棍弄,大寫(xiě)的在前面
$arr=array("file12.txt","file.txt","file2.txt","file1.txt","file11.txt");

print_r($arr);
echo '<br>';

natsort($arr);

print_r($arr);
echo '<br>';
//natcasesort 用自然排序算法對(duì)數(shù)組進(jìn)行不區(qū)分大小寫(xiě)字母的排序
$arrr=array("FILE12.TXT","file.txt","file2.txt","file1.txt","file11.txt");

natcasesort($arrr);

print_r($arrr);
echo '<br>';
//usort 使用用戶(hù)自定義的比較函數(shù)對(duì)數(shù)組中的值進(jìn)行排序
//按字符串從短到長(zhǎng)排序该园,用uasort可以保留原有鍵值名
$sz=array("#########","####","######","##");
usort($sz,function($a,$b){
  $alen=strlen($a);
  $blen=strlen($b);
  if($alen>$blen){
    return 1;
  }else if($alen<$blen){
    return -1;
  }else{
    return 0;
  }
});
print_r($sz);

array_multisort -- 對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序

<?php

// array_multisort -- 對(duì)多個(gè)數(shù)組或多維數(shù)組進(jìn)行排序
$a = array("a", 10, "b", 10);
    $b = array(1,   4,   3,  2);

    array_multisort($a,SORT_DESC, $b, SORT_DESC);

    print_r($a);  // a b 10 20
    echo '<br>';
    print_r($b);  //1  3  4  2

//對(duì)多維數(shù)組某一關(guān)鍵字進(jìn)行排序兆解,次序排序
$data = array(

            array("id"=>1, "name"=>"aa", "age"=>10),
            array("id"=>2, "name"=>"ww", "age"=>30),
            array("id"=>3, "name"=>"cc", "age"=>30),
            array("id"=>4, "name"=>"dd", "age"=>"40")

        );


    $ages = array();
    $names = array();
    foreach($data as $value) {
        $ages[] = $value['age'];
        $names[] = $value['name'];
    }




    array_multisort($ages,SORT_DESC , $names, SORT_DESC ,$data);

    echo '<pre>';
    print_r($data);
    echo '</pre>';

數(shù)組拆分、合并

      <?php
        $arr = array("a", "b", "c", "d", "e");

        $narr = array_slice($arr, -3, 2, true);

        print_r($narr);

        array_splice($arr, -3, 2, array("hello", "world"));

        print_r( $arr );

        $a = array("os", "webserver", "db", "language", "html");
        $b = array("linux", "apache", "mysql", "php");

        $narr = array_combine($a, $b);

        print_r( $narr );
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末亲雪,一起剝皮案震驚了整個(gè)濱河市勇凭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌虾标,老刑警劉巖灌砖,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件周崭,死亡現(xiàn)場(chǎng)離奇詭異喳张,居然都是意外死亡销部,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)酱虎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)擂涛,“玉大人撒妈,你說(shuō)我怎么就攤上這事〗芪妫” “怎么了棋蚌?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵谷暮,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我熄浓,道長(zhǎng),這世上最難降的妖魔是什么赌蔑? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任跷乐,我火速辦了婚禮趾浅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘浅侨。我一直安慰自己,他們只是感情好如输,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布不见。 她就那樣靜靜地躺著稳吮,像睡著了一般井濒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上喻奥,一...
    開(kāi)封第一講書(shū)人閱讀 52,394評(píng)論 1 310
  • 那天撞蚕,我揣著相機(jī)與錄音甥厦,去河邊找鬼。 笑死刀疙,一個(gè)胖子當(dāng)著我的面吹牛扫倡,可吹牛的內(nèi)容都是我干的竟纳。 我是一名探鬼主播,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼锥累,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼桶略!你這毒婦竟也來(lái)了诲宇?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤鹅心,失蹤者是張志新(化名)和其女友劉穎纺荧,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體榕茧,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡客给,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了池充。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡坑匠,死狀恐怖厘灼,靈堂內(nèi)的尸體忽然破棺而出咽瓷,到底是詐尸還是另有隱情,我是刑警寧澤闪朱,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布奋姿,位于F島的核電站,受9級(jí)特大地震影響院刁,放射性物質(zhì)發(fā)生泄漏粪狼。R本人自食惡果不足惜再榄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一困鸥、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧澜术,春花似錦猬腰、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)懈费。三九已至计露,卻和暖如春票罐,著一層夾襖步出監(jiān)牢的瞬間胶坠,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工乡数, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留闻牡,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓玖翅,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親金度。 傳聞我的和親對(duì)象是個(gè)殘疾皇子严沥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • 大家不要吐槽我寫(xiě)的亂跟伏,其實(shí)是簡(jiǎn)書(shū)的markdown編輯器有問(wèn)題,看內(nèi)容感覺(jué)寫(xiě)的很亂翩瓜。我聯(lián)系過(guò)簡(jiǎn)書(shū)的技術(shù)人員受扳,連我理...
    Airmole閱讀 961評(píng)論 0 4
  • 數(shù)組的概述 PHP 中的數(shù)組實(shí)際上是一個(gè)有序圖。圖是一種把 values 映射到 keys 的類(lèi)型兔跌。此類(lèi)型在很多方...
    dptms閱讀 1,615評(píng)論 0 4
  • php usleep() 函數(shù)延遲代碼執(zhí)行若干微秒勘高。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解包。 uni...
    思?jí)鬚HP閱讀 1,987評(píng)論 1 24
  • PHP常用函數(shù)大全 usleep() 函數(shù)延遲代碼執(zhí)行若干微秒浮定。 unpack() 函數(shù)從二進(jìn)制字符串對(duì)數(shù)據(jù)進(jìn)行解...
    上街買(mǎi)菜丶迷倒老太閱讀 1,373評(píng)論 0 20
  • 我的城市下雨了相满,我也想問(wèn)問(wèn)你的城市是否下雨层亿,可我欲言又止桦卒,因?yàn)槟且豢涛倚睦锖ε拢喝绻愕某鞘幸蚕缕鹆擞辏也辉谀?..
    柏木之舟閱讀 231評(píng)論 1 1