php元素排序算法,php 4大基础排序算法

原标题:php 4大基础排序算法

第一冒泡排序

/**

* 冒泡排序

* 思路:每次循环排列出一个最大的数

*/

publicfunctionmao_paoOp(){

$data=array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);

$total=count($data);

//循环控制需要冒的轮数

for($i=0;$i

//每轮 冒出的数 比较

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

if($data[$i]>$data[$j]){

//接收的空变量

$rem=$data[$i];

$data[$i] =$data[$j];

$data[$j] =$rem;

}

}

}

$this->response($data,2000);

}

第二选择排序

/**

* 选择排序

* 思路:每一趟在n-i+1(i = 1,2,…,n-1)个记录中选择关键字最小的记录作为有序序列中第i个记录,

* 其中最简单的是简单选择排序,其过程如下:通过n-i次关键字间的比较,

* 从n-i+1个记录中选择出关键字最小的记录,并各第i个记录交换之。

*/

publicfunctionselect_mathOp(){

$data=array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);

$total=count($data);

for($i=0;$i

//假设最小值位置

$p=$i;

//当前需要比较的元数 $i的后面

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

if($data[$p]>$data[$j]){

//发现有更小的 记录

$p=$j;

}

}

//发现最小的和当前的位置不一样 对调

if($p!=$i){

$tem=$data[$p];

$data[$p] =$data[$i];

$data[$i] =$tem;

}

}

$this->response($data,2000);

}

第三插入排序

/**

* 插入排序

* 思路:通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,

* 通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,

* 需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间

*/

publicfunctioninsert_mathOp(){

$data=array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);

$total=count($data);

for($i=1;$i

$tmp=$data[$i];

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

if($tmp

$data[$j+1] =$data[$j];

$data[$j] =$tmp;

}else{

break;

}

}

}

$this->response($data,2000);

}

第四快速排序

/**

* 快速排序

* 思路:先对数组进行分割, 把大的元素数值放到一个临时数组里,

* 把小的元素数值放到另一个临时数组里(这个分割的点可以是数组中的任意一个元素值,一般用第一个元素,即$array[0]),

* 然后继续把这两个临时数组重复上面拆分,最后把小的数组元素和大的数组元素合并起来。这里用到了递归的思想。

*/

publicfunctionquick_sort_mathOp(){

$data=array(5,2,6,4,3,1,9,8,4,5,14,25,41,12,52,32,42);

$data_tmp=$this->quick_sort($data);

$this->response($data_tmp,2000);

}

/**

* 使用递归方式

* @param $data

* @return array

*/

publicfunctionquick_sort($data){

$total=count($data);

//递归的时候 要防止死循环

if($total<=1){

return$data;

}

$base_num=$data[0];

$left_data=array();//小于

$right_data=array();//大于

for($i=1;$i

if($base_num>$data[$i]){

$left_data[] =$data[$i];

}else{

$right_data[] =$data[$i];

}

}

$left_data=$this->quick_sort($left_data);

$right_data=$this->quick_sort($right_data);

$data_tmp=array_merge($left_data,array($base_num),$right_data);

return$data_tmp;

责任编辑:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值