文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

PHP常见的几种排序算法介绍

2024-04-02 19:55

关注

这篇文章主要介绍“PHP常见的几种排序算法介绍”,在日常操作中,相信很多人在PHP常见的几种排序算法介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP常见的几种排序算法介绍”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一、冒泡排序

排序原理:对一组数据,比较相邻数据的大小,把小的数据放在前面,值大的放在后面(升序排序)

举例说明: $arr = [6, 3, 8, 2, 9, 1];

第一轮排序:

    第一次比较 6和3比较: 3    6   8   2   9   1 

    第二次比较 6和8比较: 3    6   8   2   9   1 

    第三次比较 8和2比较: 3    6   2   8   9   1 

    第四次比较 8和9比较: 3    6   2   8   9   1 

    第五次比较 9和1比较: 3    6   2   8   1   9 

第一轮比较总结:1.排序第1轮、比较5次,没有获得从小到大的排序   2.因为每次比较都是大数往后靠,所以比较完成后,可以确定大数排在最后(9 已经冒泡冒出来了,下轮比较可以不用比较了 )

第二轮排序:

    第一次比较 3和6比较: 3    6   8   2   1   9 

    第二次比较 6和8比较: 3    6   8   2   1   9 

    第三次比较 8和2比较: 3    6   2   8   1   9 

    第四次比较 8和1比较: 3    6   2   1   8   9 

第二轮比较总结:1.排序第2轮、比较4次,没有获得从小到大的排序   2.冒泡出了 8,下轮不用比较8 了

第三轮排序:

    第一次比较 3和6比较: 3    6   2   1   8   9 

    第二次比较 6和2比较: 3    2   6   1   8   9 

    第三次比较 6和1比较: 3    2   1   6   8    9 

第三轮比较总结:1.排序第3轮、比较3次,没有获得从小到大的排序   2.冒泡出了 6,下轮不用比较6 了

第四轮排序:

    第一次比较 3和2比较: 2    3   1   6   8    9

    第二次比较 3和1比较: 2    1   3   6   8   9 

第四轮比较总结:1.排序第4轮、比较2次,没有获得从小到大的排序   2.冒泡出了 3,下轮不用比较3 了

第五轮比较

第一次比较2和1比较: 1    2   3   6   8    9

第五轮比较总结:1.排序第5轮、比较1次,没有获得从小到大的排序   2.冒泡出了 2,由于还剩一个1,不用再比较了,至此通过5轮排序,完成整个排序

结论:对于一个长度为N的数组,我们需要排序 N-1 轮,每 i 轮 要比较 N-i 次。对此我们可以用双重循环语句,外层循环控制循环轮次,内层循环控制每轮的比较次数。

代码实现:

    PHP常见的几种排序算法介绍

二、选择排序

原理:在一组数据中,选出最小数与第一个位置的数交换。让胡在剩些的数再找最小的数与第二个位置的数交换,如此类推。

举例说明: $arr = [6, 3, 8, 2, 9, 1];

第一轮:

    第一次比较: 第一个数6与3  8  2  9  1中的3比较,最小数为3,位置为1

    第二次比较: 第最小数3与3  8  2  9  1中的8比较,最小数为3,位置为1

    第三次比较: 第最小数3与3  8  2  9  1中的2比较,最小数为2,位置为3

    第四次比较: 第最小数2与3  8  2  9  1中的9比较,最小数为2,位置为3

    第五次比较: 第最小数2与3  8  2  9  1中的1比较,最小数为1,位置为5

第一轮比较完成后,确定最小数为1,小于第一个数6,交换位置上的数,交换后结果为 1  3  8  2  9  6

第二轮:

    第一次比较: 第一个数3与  8  2  9  6中的8比较,最小数为3,位置为1

    第二次比较: 第最小数3与  8  2  9  6中的2比较,最小数为2,位置为3

    第三次比较: 第最小数2与  8  2  9  6中的9比较,最小数为2,位置为3

    第三次比较: 第最小数2与  8  2  9  6中的6比较,最小数为2,位置为3

第二轮比较完成后,确定最小数为2,小于第二个数3,交换位置上的数,交换后结果为 1  2  8  3  9  6、、

第三轮:

    第一次比较: 第一个数8与  3  9  6中的8比较,最小数为3,位置为3

    第二次比较: 第最小数3与  3  9  6中的9比较,最小数为3,位置为3

    第三次比较: 第最小数2与  3  9  6中的6比较,最小数为3,位置为3

第三轮比较完成后,确定最小数为3,小于第三个数8,交换位置上的数,交换后结果为 1  2  3  8  9  6

第四轮:

    第一次比较: 第一个数8与  9  6中的9比较,最小数为8,位置为3

    第二次比较: 第最小数8与  9  6中的6比较,最小数为6,位置为5

 第四轮比较完成后,确定最小数为6,小于第四个数8交换位置上的数,交换后结果为 1  2  3  6  9  8

第五轮:

    第一次比较: 第一个数 9与 8 中的8比较,最小数为8,位置为5

第五轮比较完成后,确定最小数为8,小于第五个数9,交换位置上的数,交换后结果为 1  2  3  6  8  9

 综合以上五轮比较,每一轮比较都可以确定一个位置,对于N个数,比较N-1轮可以确定N个位置上的数,因为确定了N-1个位置,最后一个位置也就确定了

代码实现:

    PHP常见的几种排序算法介绍

三、插入排序

    在要排序的一组数中,假设前面的数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序的。如此反复循环,直到全部排好顺序

  代码实现:

    PHP常见的几种排序算法介绍

四、快速排序 

    从数组第一个元素开始依次确定从小到大的元素

    代码实现:

    PHP常见的几种排序算法介绍

到此,关于“PHP常见的几种排序算法介绍”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯