PHP中涉及到多種排序,而冒泡排序應該是我用的最鬧心的一種排序,弄了老半天還是沒太懂,這篇簡單講述PHP冒泡排序的很適合像我一樣不太懂冒泡排序的東西看哦!
1.冒泡演算法
看了幾篇關於冒泡的文章,但是總是對於每次循環的邊界值思路講的比較籠統。
不是很容易被新手記住,我自己平常也是硬記下來的。
但是對於演算法,硬記,時間長了還是容易忘記,所以自己寫了一次,把每次思路盡量寫下來,便於理解,理解了容易加深映像,不容易忘記了。
氣泡演算法,核心是
1.循環比對 每次比對相鄰2個陣列的大小,然後將最大的陣列放到後面,這樣所有比對循環一次,就會把數組中最大的數放到數組最後
2. 然後重複循環(重複上面的比對循環):此時循環的時候最後一個值是不需要參加循環了,因為已經確定是最大的那個了。也就是說,重複循環,比對陣列越來越少。最後只剩下一個陣列元素了。循環結束
程式碼層看:
$arr=array(5,4,3,6,7,1,2,10,8,9);
先從兩兩比對開始看
if($arr[$i]>$arr[$i+1]){//相邻比较 这个应该比较容易理解吧 $tem=$arr[$i]; $arr[$i]=$arr[$i+1]; $arr[$i+1]=$tem; }
以上程式碼就是比對2個陣列相鄰的值大小,大的放後面。可以看出來 $i 最大就是數組索引前一位的,否則 $arr[$i+1]不存在了,無法比較。也就是說 $icount($ar)-1;$i初始值為0
先從內層比對迴圈開始看
#一般for循環 這麼寫
for($i=0;$i<$xx;$i++){ if($arr[$i]>$arr[$i+1]){//相邻比较 这个应该比较容易理解吧 $tem=$arr[$i]; $arr[$i]=$arr[$i+1]; $arr[$i+1]=$tem; } }
上面思路說了,每次比對循環都是從開頭第一個元素開始所以$i 起始值為0, 重複循環一次,下次循環就少比對一個元素。這裡$xx要越來越小; 那這個$xx怎麼確定呢?
$xx第一次循環值是多少 ?上面兩兩比對得出結論 count($ar)-1
$xx 最後一次值該是多少呢?上面兩兩比對得出結論 是1。
也就是說$xx 為 count($arr)-$k $k是累加的比對循環可改為(重複循環每循環一次)
for($i=0;$i<count($arr)-$k;$i++){ if($arr[$i]>$arr[$i+1]){//相邻比较 $tem=$arr[$i]; $arr[$i]=$arr[$i+1]; $arr[$i+1]=$tem; } }
再看這個$k想想這個$k不就是隨著重複循環在累積的嗎? 把重複循環程式碼加上如下
我們再來看下$k是怎麼確定邊界值的上面說了, $xx 邊界值是count($arr)-1 到1 已經定義 那麼數學演算法$k邊界值也就出來了為1到 count($arr)-1
寫入到迴圈裡也就是$k=1;$k 整理下就是 希望大家可以看的懂,還是多練練比較好,有的時候我們不明白的知識,自己多寫兩遍寫著寫著就懂了! for($k=1;$k<count($arr);$k++){
for($i=0;$i<count($arr)-$k;$i++){
if($arr[$i]>$[$i+1]){
$temparr= $arr[$i];
$arr[$i] =$arr[$i+1];
$arr[$i+1] = $temparr;
}
}
}
以上是簡單的理解PHP冒泡排序的詳細內容。更多資訊請關注PHP中文網其他相關文章!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

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

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境