常用算法PHP版

ChongTuWang
• 阅读 4974

下面分享一些最常见的算法,用PHP如何实现。

冒泡排序

function bubble_sort($arr) {

$n=count($arr);
for($i=0;$i<$n-1;$i++){
    for($j=$i+1;$j<$n;$j++) {
        if($arr[$j]<$arr[$i]) {
            $temp=$arr[$i];
            $arr[$i]=$arr[$j];
            $arr[$j]=$temp;
        }
    }
}
return $arr;

}

归并排序

function Merge(&$arr, $left, $mid, $right) {

$i = $left;
$j = $mid + 1;
$k = 0;
$temp = array();
while ($i <= $mid && $j <= $right) {
    if ($arr[$i] <= $arr[$j])
        $temp[$k++] = $arr[$i++];
    else
        $temp[$k++] = $arr[$j++];
}
while ($i <= $mid)
    $temp[$k++] = $arr[$i++];
while ($j <= $right)
    $temp[$k++] = $arr[$j++];
for ($i = $left, $j = 0; $i <= $right; $i++, $j++)
    $arr[$i] = $temp[$j];

}
function MergeSort(&$arr, $left, $right) {

if ($left < $right) {
    $mid = floor(($left + $right) / 2);
    MergeSort($arr, $left, $mid);
    MergeSort($arr, $mid + 1, $right);
    Merge($arr, $left, $mid, $right);
}

}

二分查找-递归

function bin_search($arr,$low,$high,$value) {

if($low>$high)
    return false;
else {
    $mid=floor(($low+$high)/2);
    if($value==$arr[$mid])
        return $mid;
    elseif($value<$arr[$mid])
        return bin_search($arr,$low,$mid-1,$value);
    else
        return bin_search($arr,$mid+1,$high,$value);
}

}

二分查找-非递归

function bin_search($arr,$low,$high,$value) {

while($low<=$high) {
    $mid=floor(($low+$high)/2);
    if($value==$arr[$mid])
        return $mid;
    elseif($value<$arr[$mid])
        $high=$mid-1;
    else
        $low=$mid+1;
}
return false;

}

快速排序

function quick_sort($arr) {

$n=count($arr);
if($n<=1)
    return $arr;
$key=$arr[0];
$left_arr=array();
$right_arr=array();
for($i=1;$i<$n;$i++) {
    if($arr[$i]<=$key)
        $left_arr[]=$arr[$i];
    else
        $right_arr[]=$arr[$i];
}
$left_arr=quick_sort($left_arr);
$right_arr=quick_sort($right_arr);
return array_merge($left_arr,array($key),$right_arr);

}

选择排序

function select_sort($arr) {

$n=count($arr);
for($i=0;$i<$n;$i++) {
    $k=$i;
    for($j=$i+1;$j<$n;$j++) {
       if($arr[$j]<$arr[$k])
           $k=$j;
    }
    if($k!=$i) {
        $temp=$arr[$i];
        $arr[$i]=$arr[$k];
        $arr[$k]=$temp;
    }
}
return $arr;

}

插入排序

function insertSort($arr) {

$n=count($arr);
for($i=1;$i<$n;$i++) {
    $tmp=$arr[$i];
    $j=$i-1;
    while($arr[$j]>$tmp) {
        $arr[$j+1]=$arr[$j];
        $arr[$j]=$tmp;
        $j--;
        if($j<0)
            break;
    }
}
return $arr;

}

点赞
收藏
评论区
推荐文章
凯特林 凯特林
4年前
JS - 用 for 循环实现常见的数组迭代方法
常见的数组迭代方法有很多种,比如some,filter,map等等,底层也都可以用for来实现,我们来康一康。somejsconstsome(arr,fn)for(leti0;i<arr.length;i)if(fn(arri,i,arr))re
西八老码 西八老码
4年前
今天就来花一点时间整理一下算法吧!
算法,就是计算机处理信息的一个步骤。是独立存在的一种处理问题的方法和思想,并不局限于具体的实现过程。排序冒泡cpublicstaticintBubbleSort(intarr)for(inti0;i<arr.length;i)for(intj0;j<a
Wesley13 Wesley13
3年前
java中几种排序的实现
1.最简单的冒泡排序/\\\冒泡排序\/publicstaticvoidbubbleSort(){int\\arr{5,8,1,2,9,8,7,4};System.out.println("排序前的数组为:");for(intnum:arr){System.o
Jacquelyn38 Jacquelyn38
4年前
这些JS工具函数够你用到2020年底了
前言活不多说,自己平时搜集的干货函数奉上。干货函数找出数字在数组中下一个相邻的元素let i  "";let rr  ;const name  (n, arr1)    let num  Number(n);    for (let i  0; i < arr1.length; i)         const elemen
CuterCorley CuterCorley
4年前
C语言基础习题50例(九)41-45
习题41学习static定义静态变量的用法。实现思路:用static声明和未用static声明变量进行对比,即可得出static的作用。代码如下:cinclude<stdio.hintmain(){voidfunc();inti;for(i0;i<10;i){func();}return
九路 九路
4年前
Java实现排序算法
//冒泡排序publicstaticvoidbubbleSort(intdata){intndata.length;for(inti0;i<n;i){for(intj0;j<n;j){if(
Wesley13 Wesley13
3年前
JAVA 中数组的几种排序方法
1、数组的冒泡排序publicvoidbubbleSort(inta){intna.length;for(inti0;i<n1;i){for(intj0;j<n1;j)
Wesley13 Wesley13
3年前
PHP算法:冒泡排序与快速排序
写一个排序算法,可以是冒泡排序或者快速排序,假设待排序对象是一个二维数组。(提示:不能使用系统已有函数,另外请仔细回忆以前学习过的基础知识)//冒泡排序<brfunctionbubble_sort($array)
{
&nbsp;&nbsp;<br$countcount($array);
&nbsp;&nb
Wesley13 Wesley13
3年前
PHP创建多级树型结构
<!lang:php<?php$areaarray(array('id'1,'pid'0,'name''中国'),array('id'5,'pid'0,'name''美国'),array('id'2,'pid'1,'name''吉林'),array('id'4,'pid'2,'n
Stella981 Stella981
3年前
PHP Curl模拟登录签到
<?php/curl登录签到201704W3Cqjd/$arr'cookstr'"";$arr'url'"http://www.w3cschool.cn/checklogin";$
Stella981 Stella981
3年前
JavaScript常用基础算法
基础算法一、排序1.冒泡排序//冒泡排序functionbubbleSort(arr){for(vari1,lenarr.length;i<len1;i){for(varj0;j<