目录
1.冒泡排序
2.选择排序
3.插入排序
4.快速排序
首页 后端开发 php教程 php基础算法有哪几种

php基础算法有哪几种

Jun 18, 2019 pm 03:44 PM
php算法

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

php基础算法有哪几种

相关推荐:《PHP教程

需求:分别用 冒泡排序法,快速排序法,选择排序法,插入排序法将下面数组中 的值按照从小到的顺序进行排序。

$arr=array(11,3,56,62,21,66,32,78,36,76,39,88,34);
登录后复制

1.冒泡排序

介绍:

冒泡排序(Bubble Sort,台湾译为:泡沫排序或气泡排序)是一种简单的排序算法。它重复地走访过要排序的数列,依次比较两个元素,如果他们的顺序错误就把他们交换过来。走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。这个算法的名字由来是因为越小的元素会经由交换慢慢“浮”到数列的顶端。

步骤:

1.比较相邻的元素。如果第一个比第二个大,就交换他们两个。

2.对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。

3.针对所有的元素重复以上的步骤,除了最后一个。

4.持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

具体代码:

$arr=array(1,43,54,62,21,66,32,78,36,76,39);
function bubbleSort ($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.选择排序

介绍:

选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理如下。首先在未排序序列中找到最小元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小元素,然后放到排序序列末尾。以此类推,直到所有元素均排序完毕。

具体代码:

//实现思路 双重循环完成,外层控制轮数,当前的最小值。内层 控制的比较次数
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;
}
登录后复制

排序效果:

2.gif

3.插入排序

介绍:

插入排序(Insertion Sort)的算法描述是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序),因而在从后向前扫描过程中,需要反复把已排序元素逐步向后挪位,为最新元素提供插入空间。

步骤:

1.从第一个元素开始,该元素可以认为已经被排序

2.取出下一个元素,在已经排序的元素序列中从后向前扫描

3.如果该元素(已排序)大于新元素,将该元素移到下一位置

4.重复步骤3,直到找到已排序的元素小于或者等于新元素的位置

5.将新元素插入到该位置中

6.重复步骤2

具体代码:

function insert_sort($arr)
{
$len=count($arr);
for($i=1; $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;
}
登录后复制

排序效果:
3.gif

4.快速排序

介绍:

快速排序是由东尼·霍尔所发展的一种排序算法。在平均状况下,排序 n 个项目要Ο(n log n)次比较。在最坏状况下则需要Ο(n2)次比较,但这种状况并不常见。事实上,快速排序通常明显比其他Ο(n log n) 算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来,且在大部分真实世界的数据,可以决定设计的选择,减少所需时间的二次方项之可能性。

步骤:

1.从数列中挑出一个元素,称为 “基准”(pivot),

2.重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作。

3.递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序。

具体代码:

function quick_sort($arr)
{
//判断参数是否是一个数组
if(!is_array($arr)) return false;
//递归出口:数组长度为1,直接返回数组
$length = count($arr);
if($length<=1) return $arr;
//数组元素有多个,则定义两个空数组
$left = $right = array();
//使用for循环进行遍历,把第一个元素当做比较的对象
for($i=1; $i<$length; $i++)
{
//判断当前元素的大小
if($arr[$i]<$arr[0]){
$left[]=$arr[$i];
}else{
$right[]=$arr[$i];
}
}
//递归调用
$left=quick_sort($left);
$right=quick_sort($right);
//将所有的结果合并
return array_merge($left,array($arr[0]),$right);
}
登录后复制

排序效果:

Visual-and-intuitive-feel-of-7-common-sorting-algorithms.gif

以上是php基础算法有哪几种的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP编程中有哪些常见的算法? PHP编程中有哪些常见的算法? Jun 12, 2023 am 08:30 AM

在PHP编程中,算法是不可或缺的一部分。掌握常见的算法,不仅可以提高代码效率,还可以为后续的程序设计提供帮助。以下是PHP编程中常见的算法:排序算法排序算法是指将一组数据按照一定的规则排列成有序的序列。在PHP编程中,常用的排序算法有冒泡排序、插入排序、选择排序、快速排序等。其中,快速排序是时间复杂度最低的一种排序算法,适合处理大规模的数据。查找算法查找算法

PHP中的数组排序及搜索算法 PHP中的数组排序及搜索算法 Jun 23, 2023 am 09:45 AM

PHP是一种非常流行的编程语言,它支持各种数据类型和算法,其中数组排序和搜索算法是基本而重要的部分。本文将会介绍PHP中常用的数组排序及搜索算法,以及它们的应用场景和效率分析。一、数组排序PHP中提供了多种数组排序的方法,包括冒泡排序、插入排序、选择排序、快速排序、归并排序等等。以下是对其中常用的几种算法的介绍及示例代码:冒泡排序(BubbleSort)冒

了解PHP数据结构和算法 了解PHP数据结构和算法 May 24, 2023 am 08:15 AM

PHP是一种广泛应用于Web开发的脚本语言,且在建立动态网站上表现得越来越好。在Web开发中,数据结构和算法的重要性并不低于其他编程范畴,其对于程序运行效率的影响尤为显着。尤其是在涉及大量数据存储和处理,或者对程序性能要求较高的场景下,数据结构和算法成为了不可忽视的一部分。本文主要介绍PHP中一些常用的数据结构和算法。一、数据结构数组PHP数组是一种非常常见

PHP中如何进行知识表示和自动生成算法? PHP中如何进行知识表示和自动生成算法? May 22, 2023 pm 08:10 PM

随着互联网的普及和应用的不断扩大,程序语言的发展也变得越来越重要。PHP作为一种非常流行的程序语言,也在不断的发展。PHP开发者在使用PHP进行编程的过程当中,可能会面对到需要对一些知识进行表示,以及需要进行自动生成算法的问题。那么,PHP中如何进行知识表示和自动生成算法呢?下面本文将会对此进行探讨。一、知识表示知识表示是人工智能领域中非常重要的一个问题。知

PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素? PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素? Sep 19, 2023 pm 01:14 PM

PHP算法解析:如何使用二分查找算法在有序数组中快速定位元素?概述:二分查找算法是一种高效的查找算法,它适用于有序数组中查找特定元素。本文将详细介绍二分查找算法的原理,并给出PHP代码示例。原理:二分查找算法通过反复将查找范围缩小一半,从而快速定位目标元素。其流程如下:首先,将查找范围缩小为数组的开头和结尾;然后,计算中间元素的索引,将其与目标元素进行比较;

深入理解PHP和Vue在脑图功能中的核心算法 深入理解PHP和Vue在脑图功能中的核心算法 Aug 15, 2023 pm 01:00 PM

深入理解PHP和Vue在脑图功能中的核心算法引言:在现代的互联网时代,我们经常使用各种各样的应用程序来帮助我们组织和管理信息。脑图是一种常见且实用的信息组织方式,它能够将复杂的思维过程以图形化的方式展示出来。在本文中,我们将着重讨论PHP和Vue在脑图功能中的核心算法,并给出代码示例。一、脑图的特点脑图是一种以中心主题为核心,通过树状结构来展示与该主题相关的

PHP算法解析:如何使用动态规划算法解决0-1背包问题? PHP算法解析:如何使用动态规划算法解决0-1背包问题? Sep 19, 2023 pm 12:33 PM

PHP算法解析:如何使用动态规划算法解决0-1背包问题?引言:动态规划是一种常用于解决优化问题的算法思想。在程序开发中,0-1背包问题是一个经典的动态规划应用场景。本文将介绍如何使用PHP编写动态规划算法来解决0-1背包问题,并提供具体的代码示例。什么是0-1背包问题?0-1背包问题是一种经典的组合优化问题。题目设定如下:有一个背包,它的容量为C。现有n个物

PHP中的算法和数据结构 PHP中的算法和数据结构 May 25, 2023 am 08:51 AM

PHP是一种广泛应用的开发语言,常用于Web应用程序的开发。然而,Web应用程序往往需要处理大量的数据,包括数据的处理、存储和查询等等,因此,在PHP中应用算法和数据结构是非常关键的技术。算法是一种在计算机编程中用来解决问题的通用方法。在编程中,我们通过设计和实现算法来解决问题,从而提高程序的效率、可维护性和可扩展性。常用的算法包括排序、搜索、分治、贪心等等

See all articles