php四种基础算法代码实例


Posted in PHP onOctober 29, 2013

php四种基础算法:冒泡,选择,插入和快速排序法
许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级phper,虽然很少接触到算法方面的东西 。但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法,我想还是要掌握的。下面是我按自己的理解,将四个方法分析一遍。
需求:分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。
$arr(1,43,54,62,21,66,32,78,36,76,39);

1. 冒泡排序法
 *     思路分析:法如其名,就是像冒泡一样,每次从数组当中 冒一个最大的数出来。
 *     比如:2,4,1    // 第一次 冒出的泡是4
 *                2,1,4   // 第二次 冒出的泡是 2
 *                1,2,4   // 最后就变成这样

 *   代码实现:

$arr=array(1,43,54,62,21,66,32,78,36,76,39);  
function getpao($arr)
{  
  $len=count($arr);
  //设置一个空数组 用来接收冒出来的泡
  //该层循环控制 需要冒泡的轮数
  for($i=1;$i<$len;$i++)
  { //该层循环用来控制每轮 冒出一个数 需要比较的次数
    for($k=0;$k<$len-$i;$k++)
    {
       if($arr[$k]>$arr[$k+1])
        {
            $tmp=$arr[$k+1];
            $arr[$k+1]=$arr[$k];
            $arr[$k]=$tmp;
        }
    }
  }
  return $arr;
}

2. 选择排序法:
选择排序法思路: 每次选择一个相应的元素,然后将其放到指定的位置

function select_sort($arr) {
//实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数
    //$i 当前最小值的位置, 需要参与比较的元素
    for($i=0, $len=count($arr); $i<$len-1; $i++) {
        //先假设最小的值的位置
        $p = $i;
        //$j 当前都需要和哪些元素比较,$i 后边的。
        for($j=$i+1; $j<$len; $j++) {
            //$arr[$p] 是 当前已知的最小值
            if($arr[$p] > $arr[$j]) {
     //比较,发现更小的,记录下最小值的位置;并且在下次比较时,
 // 应该采用已知的最小值进行比较。
                $p = $j;
            }
        }
        //已经确定了当前的最小值的位置,保存到$p中。
 //如果发现 最小值的位置与当前假设的位置$i不同,则位置互换即可
        if($p != $i) {
            $tmp = $arr[$p];
            $arr[$p] = $arr[$i];
            $arr[$i] = $tmp;
        }
    }
    //返回最终结果
    return $arr;
}

3.插入排序法
插入排序法思路:将要排序的元素插入到已经 假定排序号的数组的指定位置。

function insert_sort($arr) {
    //区分 哪部分是已经排序好的
    //哪部分是没有排序的
    //找到其中一个需要排序的元素
    //这个元素 就是从第二个元素开始,到最后一个元素都是这个需要排序的元素
    //利用循环就可以标志出来
    //i循环控制 每次需要插入的元素,一旦需要插入的元素控制好了,
    //间接已经将数组分成了2部分,下标小于当前的(左边的),是排序好的序列
    for($i=1, $len=count($arr); $i<$len; $i++) {
        //获得当前需要比较的元素值。
        $tmp = $arr[$i];
        //内层循环控制 比较 并 插入
        for($j=$i-1;$j>=0;$j--) {
   //$arr[$i];//需要插入的元素; $arr[$j];//需要比较的元素
            if($tmp < $arr[$j]) {
                //发现插入的元素要小,交换位置
                //将后边的元素与前面的元素互换
                $arr[$j+1] = $arr[$j];
                //将前面的数设置为 当前需要交换的数
                $arr[$j] = $tmp;
            } else {
                //如果碰到不需要移动的元素
           //由于是已经排序好是数组,则前面的就不需要再次比较了。
                break;
            }
        }
    }
    //将这个元素 插入到已经排序好的序列内。
    //返回
    return $arr;
}

4.快速排序法

function quick_sort($arr) {
    //先判断是否需要继续进行
    $length = count($arr);
    if($length <= 1) {
        return $arr;
    }
    //如果没有返回,说明数组内的元素个数 多余1个,需要排序
    //选择一个标尺
    //选择第一个元素
    $base_num = $arr[0];
    //遍历 除了标尺外的所有元素,按照大小关系放入两个数组内
    //初始化两个数组
    $left_array = array();//小于标尺的
    $right_array = array();//大于标尺的
    for($i=1; $i<$length; $i++) {
        if($base_num > $arr[$i]) {
            //放入左边数组
            $left_array[] = $arr[$i];
        } else {
            //放入右边
            $right_array[] = $arr[$i];
        }
    }
    //再分别对 左边 和 右边的数组进行相同的排序处理方式
    //递归调用这个函数,并记录结果
    $left_array = quick_sort($left_array);
    $right_array = quick_sort($right_array);
    //合并左边 标尺 右边
    return array_merge($left_array, array($base_num), $right_array);
}
PHP 相关文章推荐
在服务端进行目录建立、删除,文件上传、删除的过程的php代码
Sep 10 PHP
php学习笔记(三)操作符与控制结构
Aug 06 PHP
用来解析.htgroup文件的PHP类
Sep 05 PHP
Codeigniter中禁止A Database Error Occurred错误提示的方法
Jun 12 PHP
php页面缓存方法小结
Jan 10 PHP
分享十款最出色的PHP安全开发库中文详细介绍
Mar 22 PHP
PHP实现简单爬虫的方法
Jul 29 PHP
php 数组随机取值的简单实例
May 23 PHP
[原创]php简单隔行变色功能实现代码
Jul 09 PHP
PHP 年月日的三级联动实例代码
May 24 PHP
PHP实现负载均衡session共享redis缓存操作示例
Aug 22 PHP
VSCode+PHPstudy配置PHP开发环境的步骤详解
Aug 20 PHP
教你如何使用php session
Oct 28 #PHP
php字符编码转换之gb2312转为utf8
Oct 28 #PHP
使用PHP curl模拟浏览器抓取网站信息
Oct 28 #PHP
php header功能的使用
Oct 28 #PHP
简单实用的.net DataTable导出Execl
Oct 28 #PHP
php json与xml序列化/反序列化
Oct 28 #PHP
php中的boolean(布尔)类型详解
Oct 28 #PHP
You might like
免费的ip数据库淘宝IP地址库简介和PHP调用实例
2014/04/08 PHP
PHP+redis实现添加处理投票的方法
2015/11/14 PHP
Laravel 中创建 Zip 压缩文件并提供下载的实现方法
2019/04/02 PHP
php进程(线程)通信基础之System V共享内存简单实例分析
2019/11/09 PHP
jQuery模拟超链接点击效果代码
2013/04/21 Javascript
仿百度的关键词匹配搜索示例
2013/09/25 Javascript
Javascript学习笔记之函数篇(五) : 构造函数
2014/11/23 Javascript
JS实现自动变化的导航菜单效果代码
2015/09/09 Javascript
jQuery简单实现提交数据出现loading进度条的方法
2016/03/29 Javascript
Angularjs中的事件广播 —全面解析$broadcast,$emit,$on
2016/05/17 Javascript
必备的JS调试技巧汇总
2016/07/20 Javascript
教大家轻松制作Bootstrap漂亮表格(table)
2016/12/13 Javascript
JS 实现随机验证码功能
2017/02/15 Javascript
jQuery EasyUI ProgressBar进度条组件
2017/02/28 Javascript
jQuery中table数据的值拷贝和拆分
2017/03/19 Javascript
JS中cookie的使用及缺点讲解
2017/05/13 Javascript
AngularJS实现的回到顶部指令功能实例
2017/05/17 Javascript
JavaScript中Require调用js的实例分享
2017/10/27 Javascript
JavaScript程序设计高级算法之动态规划实例分析
2017/11/24 Javascript
Angular 作用域scope的具体使用
2017/12/11 Javascript
vue2.0 实现富文本编辑器功能
2019/05/26 Javascript
echarts 使用formatter 修改鼠标悬浮事件信息操作
2020/07/20 Javascript
vue 避免变量赋值后双向绑定的操作
2020/11/07 Javascript
Python中的元类编程入门指引
2015/04/15 Python
wxpython实现图书管理系统
2018/03/12 Python
pygame游戏之旅 计算游戏中躲过的障碍数量
2018/11/20 Python
Python批量生成幻影坦克图片实例代码
2019/06/04 Python
Linux下通过python获取本机ip方法示例
2019/09/06 Python
18个Python脚本可加速你的编码速度(提示和技巧)
2019/10/17 Python
浅谈Selenium 控制浏览器的常用方法
2020/12/04 Python
诺心蛋糕官网:LE CAKE
2018/08/25 全球购物
含预算的公司户外活动方案
2014/08/16 职场文书
单位工作证明
2014/10/07 职场文书
合作意向协议书
2015/01/29 职场文书
红灯733-1型14管5波段半导体收音机
2021/04/22 无线电
用Python爬取某乎手机APP数据
2021/06/15 Python