php设置排序,7种php基本排序实现方法

本文总结了一下常用的7种排序方法,并用php语言实现。

1、直接插入排序

/*

* 直接插入排序,插入排序的思想是:当前插入位置之前的元素有序,

* 若插入当前位置的元素比有序元素最后一个元素大,则什么也不做,

* 否则在有序序列中找到插入的位置,并插入

*/

function insertSort($arr) {

$len = count($arr);

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

if($arr[$i-1] > $arr[i]) {

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

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

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

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

$arr[$j] = $tmp;

}else{

break;

}

}

}

}

return $arr;

}

2、冒泡排序

/*

冒泡排序,冒泡排序思想:进行 n-1 趟冒泡排序, 每趟两两比较调整最大值到数组(子数组)末尾

*/

function bubbleSort($arr) {

$len = count($arr);

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

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

if($arr[$j] > $arr[$j+1]) {

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

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

$arr[$j] = $tmp;

}

}

}

return $arr;

}

3、简单选择排序

/*

简单选择排序, 简单排序思想:从数组第一个元素开始依次确定从小到大的元素

*/

function selectSort($arr) {

$len = count($arr);

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

$k = $i;

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

if($arr[$k] > $arr[$j]) {

$k = $j;

}

}

if($k != $i) {

$tmp = $arr[$i];

$arr[$i] = $arr[$k];

$arr[$k] = $tmp;

}

}

return $arr;

}

4、希尔排序

/*

希尔排序,希尔排序原理:将数组按指定步长分隔成若干子序列,然后分别对子序列进行排序(在这是直接)

*/

function shellSort($arr) {

$len = count($arr);

$k = floor($len/2);

while($k > 0) {

for($i = 0; $i < $k; $i++) {

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

if($arr[$j] > $arr[$j+$k]) {

$tmp = $arr[$j+$k];

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

$arr[$j] = $tmp;

}

}

}

$k = floor($k/2);

}

return $arr;

}

5、快速排序

/*

* 快速排序,快排思想:通过一趟排序将待排的记录分为两个独立的部分,其中一部分的记录的关键字均不大于

* 另一部分记录的关键字,然后再分别对这两部分记录继续进行快速排序,以达到整个序列有序,具体做法需要

* 每趟排序设置一个标准关键字和分别指向头一个记录的关键字和最后一个记录的关键字的指针。

* quickSort($arr, 0, count($arr) -1);

*/

function quickSort(&$arr,$low,$high) {

if($low < $high) {

$i = $low;

$j = $high;

$primary = $arr[$low];

while($i < $j) {

while($i < $j && $arr[$j] >= $primary) {

$j--;

}

if($i < $j) {

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

}

while($i < $j && $arr[$i] <= $primary) {

$i++;

}

if($i < $j) {

$arr[$j--] = $arr[$i];

}

}

$arr[$i] = $primary;

quickSort($arr, $low, $i-1);

quickSort($arr, $i+1, $high);

}

}

6、堆排序

/*

堆排序

*/

// 调整子堆的为大根堆的过程,$s为子堆的根的位置,$m为堆最后一个元素位置

function heapAdjust(&$arr, $s, $m) {

$tmp = $arr[$s];

// 在调整为大根堆的过程中可能会影响左子堆或右子堆

// for循环的作用是要保证子堆也是大根堆

for($j = 2*$s + 1; $j <= $m; $j = 2*$j + 1) {

// 找到根节点的左右孩子中的最大者,然后用这个最大者与根节点比较,

// 若大则进行调整,否则符合大根堆的 特点跳出循环

if($j < $m && $arr[$j] < $arr[$j+1]) {

$j++;

}

if($tmp >= $arr[$j] ) {

break;

}

$arr[$s] = $arr[$j];

$s = $j;

}

$arr[$s] = $tmp;

}

// 堆排序

function heapSort($arr) {

$len = count($arr);

// 依次从子堆开始调整堆为大根堆

for($i = floor($len/2-1); $i >= 0; $i--) {

heapAdjust($arr, $i, $len-1);

}

// 依次把根节点调换至最后一个位置,再次调整堆为大根堆,找到次最大值,

// 依次类推得到一个有序数组

for($n = $len-1; $n > 0; $n--) {

$tmp = $arr[$n];

$arr[$n] = $arr[0];

$arr[0] = $tmp;

heapAdjust($arr, 0, $n-1);

}

return $arr;

}

7、归并排序

/*

归并排序,这里实现的是两路归并

*/

// 分别将有序的$arr1[s..m]、$arr2[m+1..n]归并为有序的$arr2[s..n]

function Merge(&$arr1, &$arr2, $s, $m, $n) {

for($k = $s,$i = $s, $j = $m+1; $i <= $m && $j <= $n; $k++) {

if($arr1[$i]

$arr2[$k] = $arr1[$i++];

}else {

$arr2[$k] = $arr1[$j++];

}

}

if($i <= $m) {

for(; $i <= $m; $i++) {

$arr2[$k++] = $arr1[$i];

}

} else if($j <= $n) {

for(; $j <= $n; $j++) {

$arr2[$k++] = $arr1[$j];

}

}

}

// 递归形式的两路归并

function MSort(&$arr1, &$arr2, $s, $t) {

if($s == $t) {

$arr2[$s] = $arr1[$s];

}else {

$m = floor(($s+$t)/2);

$tmp_arr = array();

MSort($arr1, $tmp_arr, $s, $m);

MSort($arr1, $tmp_arr, $m+1, $t);

Merge($tmp_arr, $arr2, $s, $m, $t);

}

}

// 对一位数组$arr[0..n-1]中的元素进行两路归并

function mergeSort($arr) {

$len = count($arr);

MSort($arr, $arr, 0, $len-1);

return $arr;

}

使用经验

若排序的记录数目n较小时,可以采用直接插入排序和简单选择排序,当记录本身信息量较大时,用简单选择排序方法较好。

若待排序记录按关键字基本有序,适合采用直接插入排序和冒泡排序。

若n值较大时,可以采用快速排序、堆排序和归并排序。另外快速排序被认为是内部排序方法中最好的方法。

以上就是本文的全部内容,希望对大家的学习有所帮助。

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:php中文网

TAG标签:脚本

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/371061.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

170406、用uid分库,uname(用户名)上的查询怎么办

【缘起】 用户中心是几乎每一个公司必备的基础服务&#xff0c;用户注册、登录、信息查询与修改都离不开用户中心。 当数据量越来越大时&#xff0c;需要多用户中心进行水平切分。最常见的水平切分方式&#xff0c;按照uid取模分库&#xff1a; 通过uid取模&#xff0c;将数据分…

bzoj2144: 跳跳棋(二分/倍增)

思维好题&#xff01; 可以发现如果中间的点要跳到两边有两种情况&#xff0c;两边的点要跳到中间最多只有一种情况。 我们用一个节点表示一种状态&#xff0c;那么两边跳到中间的状态就是当前点的父亲&#xff0c;中间的点跳到两边的状态就是这个点的两个儿子&#xff0c;从而…

电脑投屏软件哪个好_目前当贝市场中投屏软件哪个好,最全面投屏技巧盘点

现在不管是在家里还是公司里&#xff0c;为了看一些是视频和资料&#xff0c;投屏到电视上是一件非常必要的事情&#xff0c;但是现在投屏的技巧各种各样&#xff0c;投屏的软件也是五花八门&#xff0c;小编平常也是经常投屏&#xff0c;也试过非常多的方法&#xff0c;这边分…

从零开始的全栈工程师——html篇1.2

起名方式与CSS 一.起名方式(起名方式也叫选择器) 起名的目的是为了给标签添加属性 常见的3种选择器有 标签选择器 id选择器(使用的时候加#) class选择器(使用的时候加.) 样式的要求是由选择器的权重来决定的 标签的权重为1 class的权重是10 id的权重是100 权重是可…

android开发中用到的px、dp、sp

先介绍一下这几个单位&#xff1a;px : pixels(像素),相应屏幕上的实际像素点。dip :device independent pixels&#xff0c;与密度无关的像素&#xff0c;基于屏幕密度的抽象单位。在每英寸160点的显示器上。 1dp 1px &#xff0c;即1 &#xff1a;1关系。&#xff08;dp 就是…

Spring:设置日志依赖项

这篇文章描述了如何在Spring中设置日志依赖。 它基于Dave Syer的帖子中提供的信息 。 这里提供有关Java日志记录框架的提醒。 该代码示例可在GitHub的Spring-Logging-Dependencies目录中找到。 Spring使用Jakarta Commons Logging API&#xff08;JCL&#xff09;。 不幸的是&…

【Codeforces Round #424 (Div. 2) C】Jury Marks

【Link】:http://codeforces.com/contest/831/problem/C 【Description】 有一个人参加一个比赛; 他一开始有一个初始分数x; 有k个评委要依次对这个人评分; 依照时间顺序依次给出这k个人的评分(可能为负数,负数的时候,表示分数会降低,而如果为正,则分数增加); 然后有一个…

php copy 文件夹,php删除与复制文件夹及其文件夹下所有文件的实现代码

/*复制xCopy函数用法&#xff1a;* xCopy("feiy","feiy2",1):拷贝feiy下的文件到 feiy2,包括子目录* xCopy("feiy","feiy2",0):拷贝feiy下的文件到 feiy2,不包括子目录*参数说明&#xff1a;* $source:源目录名* $destina…

安卓app开发工具_怎么开发app软件需要多少钱?主流app开发工具盘点

现在智能手机的快速普及让手机app在生活中越来越重要&#xff0c;很多企业及创业者也意识到了app的重要性&#xff0c;但是怎么开发app软件&#xff1f;有哪些主流app开发工具呢&#xff1f;这里就为大家分享一下如何快速开发app软件。一、编程app开发工具主要针对专业的程序员…

大话设计模式读书笔记(十一) 观察者模式

观察者模式&#xff1a; 书中通过小菜描述同事在公司看股票行情&#xff0c;并请求前台帮忙在老板回来时提醒同事&#xff0c;引出需求。将前台通知同事老板回来的事写成程序。未用模式实现&#xff1a; 1 //前台类2 public class Secretary {3 private List<StockObser…

解决高度塌陷

<!DOCTYPE html> <html lang"en" dir"ltr"><head><meta charset"utf-8"><title>高度塌陷解决</title><style media"screen">.box1{border: 10px #bfc993 solid;}.box2{width: 100px;height…

IBM AIX:Java进程大小监视

本文将为您提供有关如何计算在IBM AIX 5.3 OS上运行的Java VM进程的Java进程大小内存占用量的快速参考指南。 这是我关于该主题的原始文章的补充文章&#xff1a; 如何在AIX上监视Java本机内存 。 我强烈建议所有参与生产支持或AIX上部署Java应用程序开发的人员阅读此书。 为…

java 饥饿现象,Java单例模式、饥饿模式代码实例

class MyThreadScopeData {// 单例private MyThreadScopeData() {}// 提供获取实例方法public static synchronized MyThreadScopeData getThreadInstance() {// 从当前线程范围内数据集中获取实例对象MyThreadScopeData instance map.get();if (instance null) {instance n…

12. 抽象与密封

一、抽象类与抽象方法 1、抽象类与抽象方法声明&#xff1a; 抽象类&#xff1a;在面向对象的概念中&#xff0c;所有的类都是通过对象来描述&#xff0c;但并不是所有的类都用来描述对象。如果一个类中没有足够的信息来描绘一个具体的对象&#xff0c;这样的类就是抽象类。  …

pstate0 vid数值意义_天体运动的简单数值计算

&#xff08;建议阅读全文&#xff09; 预备知识 万有引力&#xff0c; 弹簧振子受迫运动的简单数值计算    下面我们来用一种极其简单的算法对单个天体在中心天体的万有引力作用下的运动进行数值计算&#xff0e; 事实上该问题存在解析解&#xff08;见开普勒三定律&#x…

集合框架

集合框架包含的内容&#xff1a; 集合框架的接口&#xff1a; List接口实现类 ArrayList 1 package com.jredu.ch01;3 import java.util.ArrayList;5 import java.util.List;7 public class ArrayListTest {9 public static void main(String[] args) { 10 // TODO…

使用CSS实现无滚动条滚动

我们都知道&#xff0c;撸页面的时候当我们的内容超出了我们的div&#xff0c;往往会出现滚动条&#xff0c;影响美观。 尤其是当我们在做一些导航菜单的时候。滚动条一出现就破坏了UI效果。 我们不希望出现滚动条&#xff0c;也不希望超出去的内容被放逐&#xff0c;就要保留…

Java中的类型安全的空集合

我之前曾在Java Collections类的实用程序上进行过博客撰写&#xff0c;并且特别地在使用Usings Collections Methods上的博客emptyList&#xff08;&#xff09;&#xff0c;emptyMap&#xff08;&#xff09;和emptySet&#xff08;&#xff09;上进行了博客撰写。 在本文中&a…

php cpu mac,PHP 获得计算机的唯一标识[CPU,网卡 MAC地址]

//获取电脑的CPU信息function OnlyU(){$a ;$b array();if(function_exists(exec)){if(mailto:!exec( /all",$b)){return false;}}elseif(function_exists(system)){ob_start();if(mailto:!system( /all")){return false;}else{}$b ob_get_contents();ob_end_clean…

剑指offer二十二之从上往下打印二叉树

一、题目 从上往下打印出二叉树的每个节点&#xff0c;同层节点从左至右打印。 二、思路 二叉树的层次遍历&#xff0c;可以借助队列实现。具体思路详见注释。 三、代码 import java.util.ArrayList; import java.util.LinkedList; /** public class TreeNode {int val 0;Tree…