热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php四种基础算法:冒泡,选择,插入和快速排序法

许多人都说算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级phper,虽然很少接触到算法方面的东西。但是对于冒泡排序,插入排序,选择排序,快速排序四种基本算法

 许多人都说 算法是程序的核心,一个程序的好于差,关键是这个程序算法的优劣。作为一个初级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); 
} 

推荐阅读
  • 阿里Treebased Deep Match(TDM) 学习笔记及技术发展回顾
    本文介绍了阿里Treebased Deep Match(TDM)的学习笔记,同时回顾了工业界技术发展的几代演进。从基于统计的启发式规则方法到基于内积模型的向量检索方法,再到引入复杂深度学习模型的下一代匹配技术。文章详细解释了基于统计的启发式规则方法和基于内积模型的向量检索方法的原理和应用,并介绍了TDM的背景和优势。最后,文章提到了向量距离和基于向量聚类的索引结构对于加速匹配效率的作用。本文对于理解TDM的学习过程和了解匹配技术的发展具有重要意义。 ... [详细]
  • PHP玩家基地系统毕业设计(附源码、运行环境)的用户登录界面、游戏管理和玩家作品管理
    本文介绍了一个PHP玩家基地系统的毕业设计,包括用户登录界面、游戏管理和玩家作品管理等功能。附带源码和运行环境,并提供免费赠送本源代码和数据库的方式,请私信获取详细信息。摘要共计约XXX字。 ... [详细]
  • 本文介绍了《中秋夜作》的翻译及原文赏析,以及诗人当代钱钟书的背景和特点。通过对诗歌的解读,揭示了其中蕴含的情感和意境。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 本文描述了作者第一次参加比赛的经历和感受。作者是小学六年级时参加比赛的唯一选手,感到有些紧张。在比赛期间,作者与学长学姐一起用餐,在比赛题目中遇到了一些困难,但最终成功解决。作者还尝试了一款游戏,在回程的路上感到晕车。最终,作者以110分的成绩取得了省一会的资格,并坚定了继续学习的决心。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 关羽败走麦城时路过马超封地 马超为何没有出手救人
    对当年关羽败走麦城,恰好路过马超的封地,为啥马超不救他?很感兴趣的小伙伴们,趣历史小编带来详细的文章供大家参考。说到英雄好汉,便要提到一本名著了,没错,那就是《三国演义》。书中虽 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
author-avatar
我从不在乎O心痛
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有