php数组排序的各种方法总结
对于php数组排序在php中提供了很多的函数,下面我列出来,不全的大家可以补充。
sort() 函数用于对数组单元从低到高进行排序。
rsort() 函数用于对数组单元从高到低进行排序。
asort() 函数用于对数组单元从低到高进行排序并保持索引关系。
arsort() 函数用于对数组单元从高到低进行排序并保持索引关系。
ksort() 函数用于对数组单元按照键名从低到高进行排序。
krsort() 函数用于对数组单元按照键名从高到低进行排序。
不过今天我们主要是不是讲php自带的数组排序函数主要是讲自定的排序
一、冒泡排序法
说明:找到最大的数,排列到最后面,然后继续找
例:
代码如下 | 复制代码 |
$arr = array(3,5,-1,0,2); for($i=0;$i $temp = $arr[$j]; $arr[$j]=$arr[$j+1]; $arr[$j+1]=$temp; } } } |
理解:
3,5,-1,0,2
//从第一个数开始往后比较,如果比后面的数大则与后面的数调位置
//第一次,3小于5,那么不变
//第二次,5大于-1,那么变成
3,-1,5,0,2
//第三次,5大于0
3,-1,0,5,2
//第四次,5大于2
3,-1,0,2,5
至此完成一次内循环,此时最后一个数完成排序,下次将不参与
3,-1,0,2,5第二次外循环开始 第一次:3大于-1
-1,3,0,2,5
第二次:3大于0
-1,0,3,2,5
第三次:3大于2
-1,0,2,3,5
至此完成后面两位数的排序了,接下来类推
-1,0,2,3,5
二、选择排序法 说明:先假设第一个数就是最小的数,然后将后面的数依次与它比较,如果假设的数不是最小的数,就将它与后面的最小的数调换位置
代码如下 | 复制代码 |
$arr=array(2,1,-1,3,0); for($i=0;$i $minindex = $i; for($j=1+$i;$j $minindex = $j; } } $temp = $arr[$i]; $arr[$i] = $arr[$minindex]; $arr[$minindex] = $temp; } |
理解:
2,1,-1,3,0
//先假设第一个数2为最小值,它后面的数依次与2做比较,寻找到最小的那个数
过程:
1小于2,那么minval=1
-1小于1,那么minval=-1
3大于-1,不变
0大于-1,不变
那么现在就找到了该数组中最小的数了为-1
将-1与2调换位置就完成第一个数的排序了
那么现在数组变成
-1,1,2,3,0
现在第一个数-1已经为有序,所以不参与比较了,往后面继续
现在假设minval=1
2大于1,不变
3大于1,不变
0小于1,那么minval=0
现在一次循环完成,调换0与1的位置完成第二个数的排序
那么现在数组变成
-1,0,2,3,1
//后面的推法与上面相同。。。
三、插入排序法说明:先假设一个数组中的第一个数为单独的有序数组,再将后面的一个数与它【这里随它I的增长,就变成它们了】做比较,如果后面的数比假设的数还小,则将小的那个数后移,最后将那个数移到最前面
代码如下 | 复制代码 |
$arr=array(2,1,-1,3,0); for($i=1;$i $insertindex = $i-1; while($insertindex>=0 && $insertval $arr[$insertindex+1]=$arr[$insertindex]; $insertindex--; } $temp = $arr[$i]; $arr[$insertindex+1]=$insertval; } |
理解:
2,1,-1,3,0
//第一次,先保存待插入的数1为insertval,再拿 insertval 与2比较,1小于2,所以把2后移,变成如下的图
2,2,-1,3,0
//此时2前面没有数字了,insertindex=0,所以比较完成,那么将insertval插入到寻找到的这个位置。变成如下图
1,2,-1,3,0
//此时,1,2变成有序数组
//第二次,先保存待插入的数-1为insertval,再拿insertval与2做比较,-1小于2,所以把2后移,变成如下图
1,2,2,3,0
//此时,再拿insertval与1做比较,-1小于1,那么把-1后移,变成如下图(这就是一个拿待插入数与前面的有序数组比较的过程)
1,1,2,3,0
//此时,insertindex到头了,所以将insertval插入该位置
-1,1,2,3,0
//后面推法如上
二维数组排序函数,可以实现类似 MySQL 的 ORDER BY 效果,当数组不是从数据库取得时会有特殊应用。
代码如下 | 复制代码 |
// 说明:PHP中二维数组的排序方法 |
至于一维数组排序我们用php自带的函数就可以完全实现数据排序了,所以我们讲到的都是相对用自定函数无法完成我们需求的做法了。
本文地址:
转载随意,但请附上文章地址:-)

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

如何使用PHP數組實現圖表和統計圖的生成和顯示PHP是一種廣泛使用的伺服器端腳本語言,具有強大的資料處理和圖形生成能力。在Web開發中,經常需要展示資料的圖表和統計圖,透過PHP數組,我們可以輕鬆實現這些功能。本文將介紹如何使用PHP數組產生和顯示圖表和統計圖,並提供相關的程式碼範例。引入必要的庫文件和樣式表在開始之前,我們需要在PHP文件中引入一些必要的庫文

如何使用PHP陣列產生動態投影片和圖片展示投影片和圖片展示是網頁設計中常見的功能,常被應用於輪播圖、圖庫展示等場景。而PHP作為一種流行的伺服器端腳本語言,具備處理資料和產生動態HTML頁面的能力,非常適合用於產生動態投影片和圖片展示。本文將介紹如何使用PHP陣列產生動態投影片和圖片展示,並給出對應的程式碼範例。準備圖片資料首先,我們需要準備一組圖片的路徑數據

如何使用PHP陣列實現使用者登入和權限管理的功能在開發網站時,使用者登入和權限管理是非常重要的功能之一。透過使用者登錄,我們可以驗證使用者身分並保護網站的安全性。而權限管理則能夠控制使用者在網站中的操作權限,確保使用者只能存取他們被授權的功能。在本文中,我們將介紹如何使用PHP陣列來實現使用者登入和權限管理的功能。我們將使用一個簡單的範例來演示這個過程。首先,我們需要創建

php數組求平均值的函數有:1、array_sum(),用於計算數組中所有值的總和,為了計算平均值,可以將數組中的所有值相加,然後除以數組元素的數量;2 、array_reduce(),用於迭代數組並將每個值與一個初始值進行計算;3、array_mean(),用於返回數組的平均值,先計算數組的總和,併計算數組元素的個數,將總和除以數組元素的個數,即得到平均值。

php判斷陣列有幾個的方法:1、使用count()函數,適用於所有類型的陣列。但要注意的是,如果傳入的參數不是數組,count()函數會傳回0;2、使用sizeof()函數,更多用於保持與其他程式語言的相容性;3、自訂函數,透過使用循環遍歷數組,每遍歷一次,計數器加1,最終得到數組的長度。自訂函數可以根據實際需求進行修改和擴展,更加靈活。

PHP數組是一種非常常見的資料結構,在開發過程中常會用到。然而,隨著資料量的增加,數組的效能可能會成為一個問題。本文將探討一些PHP數組的效能最佳化技巧,並提供具體的程式碼範例。 1.使用適當的資料結構在PHP中,除了普通數組外,還有一些其他資料結構,如SplFixedArray、SplDoublyLinkedList等,它們在特定情況下可能比普通數組效能更好

php數組鍵值對是一種資料結構,由一個鍵和一個對應的值組成,鍵是數組元素的標識符,而值是與鍵相關聯的資料。允許我們以鍵為標識來儲存和存取數據,透過使用鍵值對,可以更方便地操作和管理數組中的元素,使得程式開發更加靈活和高效。

php判斷數組為空的函數是「empty()」函數和「count()」函數。 1.「empty()」函數,用於判斷變數是否為空,包括判斷數組是否為空,其語法為「empty($variable)」;2、「count()」函數,用於統計數組中的元素個數,其語法為「count($array)」。
