目录
php实现四种基本排序算法
首页 后端开发 php教程 php实现四种基本排序算法_PHP教程

php实现四种基本排序算法_PHP教程

Jul 13, 2016 am 09:56 AM
算法

php实现四种基本排序算法

排序数组:$arr(1,43,54,62,21,66,32,78,36,76,39);

 

用四种排序算法进行排序

 

冒泡排序:(思路:对未排好序的数,从前往后两个数一次进行比较和调整,大的下沉,小的上升)

 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

$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

登录后复制

选择排序:(在一组数中找出最小的那个数与第一个数交换位置,在剩下的数种再找出最小的与第二个位置的数交换,

一次继续,直到倒数第二个数与最后一个数比较位置)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

function selectSort($arr) { 

//双重循环完成,外层控制轮数,内层控制比较次数 

$len=count($arr); 

for($i=0; $i<$len-1; $i++) { 

//先假设最小的值的位置 

$p = $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

登录后复制

插入排序:(假设前面的数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。

如此反复循环,直到全部排好顺序)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

function insertSort($arr) { 

$len=count($arr);  

for($i=1, $i<$len; $i++) { 

$tmp = $arr[$i]; 

//内层循环控制,比较并插入 

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

if($tmp < $arr[$j]) { 

//发现插入的元素要小,交换位置,将后边的元素与前面的元素互换 

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

$arr[$j] = $tmp

} else

//如果碰到不需要移动的元素,由于是已经排序好是数组,则前面的就不需要再次比较了。 

break

return $arr

登录后复制

快速排序:(选择一个基准元素,通常选择第一个元素或者最后一个元素。通过一趟扫描,将待排序列分成两部分,

一部分比基准元素小,一部分大于等于基准元素,此时基准元素在其排好序后的正确位置,然后再用同样的方法递归地

排序划分的两部分。 )

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

function quickSort($arr) { 

//先判断是否需要继续进行 

$length = count($arr); 

if($length <= 1) { 

return $arr

//选择第一个元素作为基准 

$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); 

}

登录后复制


 

 

 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/987358.htmlTechArticlephp实现四种基本排序算法 排序数组:$arr(1,43,54,62,21,66,32,78,36,76,39); 用四种排序算法进行排序 冒泡排序:(思路:对未排好序的数,从前往...
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系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脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

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

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

CLIP-BEVFormer:显式监督BEVFormer结构,提升长尾检测性能 CLIP-BEVFormer:显式监督BEVFormer结构,提升长尾检测性能 Mar 26, 2024 pm 12:41 PM

写在前面&笔者的个人理解目前,在整个自动驾驶系统当中,感知模块扮演了其中至关重要的角色,行驶在道路上的自动驾驶车辆只有通过感知模块获得到准确的感知结果后,才能让自动驾驶系统中的下游规控模块做出及时、正确的判断和行为决策。目前,具备自动驾驶功能的汽车中通常会配备包括环视相机传感器、激光雷达传感器以及毫米波雷达传感器在内的多种数据信息传感器来收集不同模态的信息,用于实现准确的感知任务。基于纯视觉的BEV感知算法因其较低的硬件成本和易于部署的特点,以及其输出结果能便捷地应用于各种下游任务,因此受到工业

使用C++实现机器学习算法:常见挑战及解决方案 使用C++实现机器学习算法:常见挑战及解决方案 Jun 03, 2024 pm 01:25 PM

C++中机器学习算法面临的常见挑战包括内存管理、多线程、性能优化和可维护性。解决方案包括使用智能指针、现代线程库、SIMD指令和第三方库,并遵循代码风格指南和使用自动化工具。实践案例展示了如何利用Eigen库实现线性回归算法,有效地管理内存和使用高性能矩阵操作。

探究C++sort函数的底层原理与算法选择 探究C++sort函数的底层原理与算法选择 Apr 02, 2024 pm 05:36 PM

C++sort函数底层采用归并排序,其复杂度为O(nlogn),并提供不同的排序算法选择,包括快速排序、堆排序和稳定排序。

九章云极DataCanvas多模态大模型平台的实践和思考 九章云极DataCanvas多模态大模型平台的实践和思考 Oct 20, 2023 am 08:45 AM

一、多模态大模型的历史发展上图这张照片是1956年在美国达特茅斯学院召开的第一届人工智能workshop,这次会议也被认为拉开了人工智能的序幕,与会者主要是符号逻辑学届的前驱(除了前排中间的神经生物学家PeterMilner)。然而这套符号逻辑学理论在随后的很长一段时间内都无法实现,甚至到80年代90年代还迎来了第一次AI寒冬期。直到最近大语言模型的落地,我们才发现真正承载这个逻辑思维的是神经网络,神经生物学家PeterMilner的工作激发了后来人工神经网络的发展,也正因为此他被邀请参加了这个

改进的检测算法:用于高分辨率光学遥感图像目标检测 改进的检测算法:用于高分辨率光学遥感图像目标检测 Jun 06, 2024 pm 12:33 PM

01前景概要目前,难以在检测效率和检测结果之间取得适当的平衡。我们就研究出了一种用于高分辨率光学遥感图像中目标检测的增强YOLOv5算法,利用多层特征金字塔、多检测头策略和混合注意力模块来提高光学遥感图像的目标检测网络的效果。根据SIMD数据集,新算法的mAP比YOLOv5好2.2%,比YOLOX好8.48%,在检测结果和速度之间实现了更好的平衡。02背景&动机随着远感技术的快速发展,高分辨率光学远感图像已被用于描述地球表面的许多物体,包括飞机、汽车、建筑物等。目标检测在远感图像的解释中

人工智能可以预测犯罪吗?探索CrimeGPT的能力 人工智能可以预测犯罪吗?探索CrimeGPT的能力 Mar 22, 2024 pm 10:10 PM

人工智能(AI)与执法领域的融合为犯罪预防和侦查开辟了新的可能性。人工智能的预测能力被广泛应用于CrimeGPT(犯罪预测技术)等系统,用于预测犯罪活动。本文探讨了人工智能在犯罪预测领域的潜力、目前的应用情况、所面临的挑战以及相关技术可能带来的道德影响。人工智能和犯罪预测:基础知识CrimeGPT利用机器学习算法来分析大量数据集,识别可以预测犯罪可能发生的地点和时间的模式。这些数据集包括历史犯罪统计数据、人口统计信息、经济指标、天气模式等。通过识别人类分析师可能忽视的趋势,人工智能可以为执法机构

算法在 58 画像平台建设中的应用 算法在 58 画像平台建设中的应用 May 09, 2024 am 09:01 AM

一、58画像平台建设背景首先和大家分享下58画像平台的建设背景。1.传统的画像平台传统的思路已经不够,建设用户画像平台依赖数据仓库建模能力,整合多业务线数据,构建准确的用户画像;还需要数据挖掘,理解用户行为、兴趣和需求,提供算法侧的能力;最后,还需要具备数据平台能力,高效存储、查询和共享用户画像数据,提供画像服务。业务自建画像平台和中台类型画像平台主要区别在于,业务自建画像平台服务单条业务线,按需定制;中台平台服务多条业务线,建模复杂,提供更为通用的能力。2.58中台画像建设的背景58的用户画像

PHP算法解析:查找数组中缺失数字的高效方法 PHP算法解析:查找数组中缺失数字的高效方法 Mar 02, 2024 am 08:39 AM

PHP算法解析:查找数组中缺失数字的高效方法在开发PHP应用过程中,经常会遇到需要查找数组中缺失数字的情况。这种情况在数据处理和算法设计中很常见,因此我们需要掌握高效的查找算法来解决这个问题。本文将介绍一种高效的方法来查找数组中缺失数字,并附上具体的PHP代码示例。问题描述假设我们有一个包含1到100之间的整数的数组,但其中有一个数字缺失了。我们需要设计一个

See all articles