可以把數(shù)字放到數(shù)組中,然后使用sort
員工經(jīng)過長(zhǎng)期磨合與沉淀,具備了協(xié)作精神,得以通過團(tuán)隊(duì)的力量開發(fā)出優(yōu)質(zhì)的產(chǎn)品。成都創(chuàng)新互聯(lián)堅(jiān)持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因?yàn)椤皩W⑺詫I(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡(jiǎn)單”。公司專注于為企業(yè)提供網(wǎng)站設(shè)計(jì)制作、做網(wǎng)站、微信公眾號(hào)開發(fā)、電商網(wǎng)站開發(fā),微信小程序定制開發(fā),軟件定制網(wǎng)站等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。
將數(shù)組排序:例如
$arr=array(3,1,20,10,99,5);
asort($arr);
print_r($arr)
結(jié)果為:
Array
(
[0]
=
1
[1]
=
3
[2]
=
5
[3]
=
10
[4]
=
20
[5]
=
99
)
然后再做你想要的操作
你好,建議使用冒泡排序法,這樣看上去比較清楚明了,你這樣編寫就比較復(fù)雜了。
注:為方便描述,下面的排序全為正序(從小到大排序)
假設(shè)有一個(gè)數(shù)組[a,b,c,d]
冒泡排序依次比較相鄰的兩個(gè)元素,如果前面的元素大于后面的元素,則兩元素交換位置;否則,位置不變。具體步驟:
1,比較a,b這兩個(gè)元素,如果ab,則交換位置,數(shù)組變?yōu)椋篬b,a,c,d]
2,比較a,c這兩個(gè)元素,如果ac,則位置不變,數(shù)組變?yōu)椋篬b,a,c,d]
3,比較c,d這兩個(gè)元素,如果cd,則交換位置,數(shù)組變?yōu)椋篬b,a,d,c]
完成第一輪比較后,可以發(fā)現(xiàn)最大的數(shù)c已經(jīng)排(冒)在最后面了,接著再進(jìn)行第二輪比較,但第二輪比較不必比較最后一個(gè)元素了,因?yàn)樽詈笠粋€(gè)元素已經(jīng)是最大的了。
第二輪比較結(jié)束后,第二大的數(shù)也會(huì)冒到倒數(shù)第二的位置。
依次類推,再進(jìn)行第三輪,,,
就這樣最大的數(shù)一直往后排(冒),最后完成排序。所以我們稱這種排序算法為冒泡排序。
選擇排序是一種直觀的算法,每一輪會(huì)選出列中最小的值,把最小值排到前面。具體步驟如下:
插入排序步驟大致如下:
快速排序是由東尼·霍爾所發(fā)展的一種排序算法。在平均狀況下,排序 n 個(gè)項(xiàng)目要Ο(n log n)次比較。在最壞狀況下則需要Ο(n2)次比較,但這種狀況并不常見。事實(shí)上,快速排序通常明顯比其他Ο(n log n) 算法更快,因?yàn)樗膬?nèi)部循環(huán)(inner loop)可以在大部分的架構(gòu)上很有效率地被實(shí)現(xiàn)出來,且在大部分真實(shí)世界的數(shù)據(jù),可以決定設(shè)計(jì)的選擇,減少所需時(shí)間的二次方項(xiàng)之可能性。
步驟:
從數(shù)列中挑出一個(gè)元素,稱為 “基準(zhǔn)”(pivot),
重新排序數(shù)列,所有元素比基準(zhǔn)值小的擺放在基準(zhǔn)前面,所有元素比基準(zhǔn)值大的擺在基準(zhǔn)的后面(相同的數(shù)可以到任一邊)。在這個(gè)分區(qū)退出之后,該基準(zhǔn)就處于數(shù)列的中間位置。這個(gè)稱為分區(qū)(partition)操作。
遞歸地(recursive)把小于基準(zhǔn)值元素的子數(shù)列和大于基準(zhǔn)值元素的子數(shù)列排序。