ホームページ > php教程 > php手册 > php实例代码:各种排序的算法

php实例代码:各种排序的算法

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-13 09:28:32
オリジナル
1113 人が閲覧しました

php实例代码:各种排序的算法

  

  //冒泡排序

  function maopao_sort($demo){

  $num = count($demo);

  for($i=0;$i

  for($j=$num-1;$j>$i;$j--){

  if($demo[$j]

  $temp = $demo[$j];

  $demo[$j]=$demo[$j-1];

  $demo[$j-1]= $temp;

  }

  }

  }

  return $demo;

  }

  //插入排序

  function charu_sort($demo){

  $num = count($demo);

  for($i=1;$i

  $temp=$demo[$i];

  $dqweizhi = $i-1;//记录当前位置

  while(($dqweizhi>=0)&&($temp

  $demo[$dqweizhi+1] = $demo[$dqweizhi];

  $dqweizhi--;

  }

  $demo[$dqweizhi+1] = $temp;

  }

  return $demo;

  }

  //选择法排序

  function select_sort($demo){

  $num = count($demo);

  for($i=0;$i

  $temp=$demo[$i];

  $dqweizhi=$i;

  for($j=$i+1;$j

  if($demo[$j]

  $temp=$demo[$j];

  $dqweizhi=$j;

  }

  }

  $demo[$dqweizhi]=$demo[$i];

  $demo[$i]=$temp;

  }

  return $demo;

  }

  //快速排序

  function quick_sort($demo)

  {

  $num = count($demo);

  if($num

  return $demo;

  }

  $key=$demo[0];

  $left_array=array();

  $right_array=array();

  for($i=1;$i

  if($demo[$i]

  $left_array[]=$demo[$i];

  }else{

  $right_array[]=$demo[$i];

  }

  }

  $left_array =quick_sort($left_array);

  $right_array=quick_sort($right_array);

  return array_merge($left_array,array($key),$right_array);

  }

  $test = array('43','154','3','78','13','284','167','2','56','2234','121','57','345');

  $sss = quick_sort($test);

  var_dump($sss);

  ?>

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
PHP 拡張子 intl
から 1970-01-01 08:00:00
0
0
0
phpのデータ取得?
から 1970-01-01 08:00:00
0
0
0
PHP GET エラー レポート
から 1970-01-01 08:00:00
0
0
0
phpを上手に学ぶ方法
から 1970-01-01 08:00:00
0
0
0
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート