亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 邏輯算法 > 正文

php項目開發中用到的快速排序算法分析

2020-03-22 19:29:35
字體:
來源:轉載
供稿:網友
本文實例講述了php項目開發中用到的快速排序算法。分享給大家供大家參考,具體如下:實際上在,做web開發,比較少遇到使用一些算法之類的,畢竟不是做搜索引擎,也不是寫底層(比如寫個類似于mysql這樣的數據庫,里面需要自己實現排序算法),另外,每種語言,比如java,php都或多或少已經封裝好排序函數給程序員使用。比如有個共識,大家做web開發的基本都明白,業務邏輯多比較簡單,不是很復雜的業務邏輯。我們作為web開發的程序員,基本是是web架構,對數據庫增刪查改數據,然后把數據展示在頁面中,大多就是涉及性能優化,緩存等等。學學一些常見的算法,對于實現特殊的應用還是有幫助的。比如有些時候我們依賴于數據庫中order by來實現排序了,所以非常習慣直接接下交給數據庫實現排序了。
接下來,我就遇到需要自己實現排序了。 因為我們在實際開發中,遇到一個問題,完全需要我自己實現排序。需求如下:在商品表里面,有一個字段是goods_price(商品價格),現在要開發一個促銷價功能。促銷價有個時間范圍設置。在前臺頁面中,展示商品的時候。如果當前時間符合促銷時間。就要按照促銷價格執行。于是促銷價就單獨增加了一個字段來保存,叫做promote_price,促銷時間配置信息比如什么時間,每天幾點到幾點之類的時間設置信息暫時不管,存儲在其他字段中的,展示的時候,要用當前時間跟配置的時間進行比較。單條商品展示的時候,就直接判斷是否在促銷時間內即可了。沒遇到排序的問題。而是在做商品列表頁面的時候,一個這樣的小細節就讓我發現需求:用戶可以選擇商品價格按照"從高到低"也可以選擇"從低到高"排序。如果是單純排序,以往是直接交給數據庫去排序,一般我們習慣了sql中使用"order by goods_price DESC"之類的語句就能實現按照價格降序還是升序進行?,F在,不能簡單就按照goods_price(商品價格)排序就ok。比如當前時間有的商品是符合促銷時間的,那么促銷價也是要作為排序的。簡單的 order by goods_price DESC,promote_price DESC 這種做法的話完全是不對路現在的需求。所以呢,需要先對交給數據庫的order by goods_price DESC 排序一次,列出數據。然后遍歷,看哪些商品數據是符合促銷價格的。然后自己編寫代碼實現排序。我初期想法是:拿到當前頁的數據,里面判斷每行是否符合促銷價時間點foreach(經過數據庫按照價格字段排序的結果)if ($v['promote_price'] 0 && $promote_html' target='_blank'>class- promtoe_validate($food_info)) { $v['is_promote'] = true; $v['price']= $v['promote_price']; //將原價改為促銷價顯示對上面的列表,因為上面的列表經過mysql排序一次后,還經過了促銷價。所以還需要再次編寫一個排序算法排序一次。這樣就可以把促銷價低的放到前面去了其實,mysql數據庫就是用c語言編寫的。我理解數據庫order by,它的排序也就是用c語言實現對數組的排序(關系表里面返回的的行列表就是一個二維數組)只是,平時我們排序是交給數據庫去實現了。很少自己編寫,所以因為接觸不多,就以為這些算法自己用不上,現在仍然需要用php語言對數據去實現排序。數據庫中的 order by a DESC,b ASC 的實現原理猜測 第一種理解:先按照a字段進行排序。然后又對數據按照b字段進行排序。
第二種理解:先按照a字段進行排序 ,如果遇到兩個值相同的,無法確定誰在前在后時,則使用b asc來確定兩個數據的先后順序。我是第一種理解,后來糾正,第二種理解才是對符合對的,因為這才比較符合設計的考慮點:為什么要設計可以多個字段進行排序?難道是為了相互覆蓋掉嗎?比如先按照a字段排序了。某兩項數據本來是一個在前一個在后,如果又按照b asc進行排序,那么可能原來這兩項數據的順序就可能錯位,就是可能導致后面的排序規則應用后的結果覆蓋前面的。假設數據庫排序是這樣子設計的話就沒實際意義了。之所以設計多個字段進行排序。就是為了解決,遇到兩行中a字段的值都2,2的時候,怎么確定先后?這個時候就調用后面的排序規則對這兩項數據排序。所以order by 后面的字段先后順序不同造成的效果是不同的?,F實生活例子:假設要排名100個學生的英語成績,假設排序的時候,遇到三個學生都是88分。誰排名在前呢?這個時候可以附加一種新的排序方式,對這三個學生看他們的品行分排序。這樣子就好確定了。網上的快速排序法,實現都是針對一維數組來實現的?,F在我要模擬數據庫中的行,也就是二維數組作為參數,并且可以指定任意字段作為排序方式。比如從數據庫中查詢出一個數據列表,原封不動的對這個列表可以指定某個字段進行排序(數據庫就是實現這個需求吧。當然他們要先進得些。人家牛逼些 呵呵。具體,看下面: * 排序:此函數是一個通用函數,只要是二維數組的排序都可以調用。初衷是解決價格快速排序(涉及到促銷價,無法使用order by解決) * +-------------------------------------------------------------------------- * @param $arr 要排序的數組,二維數組。對應就是數據庫中的多行數據 array( * 0= array("字段1"= '','字段2'= ''...) * 1= array("字段1"= '','字段2'= ''...) * 2= array("字段1"= '','字段2'= ''...) * +-------------------------------------------------------------------------- * @param $key_field 按照哪個字段進行排序,不要傳入一個并不存在的字段。會打亂原來的順序 * +-------------------------------------------------------------------------- * @param $sort_type = asc or desc 排序方式。從小大到大,還是從大到小function quickSort($arr, $key_field, $sort_type = "asc") { if (count($arr) 1) { //使用哪個字段排序,先得到該字段所有數據,目的是轉換成一維數組進行排序 $key_value_arr = array(); $return_arr = array(); //先判斷排序的字段是否存在 foreach ($arr as $k = $v) { $key_value_arr[$k] = $v[$key_field]; //得到這個字段的值 //php內置函數實現了按降序還是升序排,但是只支持一維數組 if ($sort_type == 'desc') { arsort($key_value_arr); } else { asort($key_value_arr); reset($key_value_arr); foreach ($key_value_arr as $k = $v) { $return_arr[$k] = $arr[$k]; //得到行 return $return_arr; } else { return $arr;總結一下我對快速排序法的理解假設有100個元素,對此進行排序。那么需要遍歷多少次呢?仍然需要遍歷至少100次。因為確實都免不了,逐個去掃描每個元素,丟到左邊,還是右邊。當第一次分割之后。還要繼續對分割后兩邊的進行重復這一步驟。
當元素數量小的時候,是體會不到區別的。如果數量很大,達到上萬個元素。需要進行排序,則需要涉及到算法了
比如比較高矮,現實中情況,我們人可以用眼睛來看,哪個更小,然后認為的排序出來。但是計算機則不同。我們必須編寫程序來告訴它要什么樣的方法實現。快速排序體現的思想是:分治法。分割成小塊,逐個解決。大體的思路描述:1、從一堆數據里面找到一個基準的數據。按照這個數據標準分割開來。現實例子,一堆人100個人,比較高矮?,F在我找出一個高度的人,我按照這個人的身高,分成a,b兩組。比他矮的都站到a組,比他高的都站到b(跟他一樣高的隨便放哪一邊都可以),這樣子可將100個人分割成兩組人。
結果是,a組里面的所有人身高都要 =b組里面的人。
2、對a組里面的人重復第一步。對b組里面的人也重復第一步。
3、直到最后只剩下一個(因為已經沒法在繼續切割了),才分組。我學到一個思想:先切成大塊,然后對每個大塊單獨處理。最后把各個塊的處理結果都合并起來。function quickSort($arr) { if(count($arr) 1) { $k=$arr[0]; $x=array(); $y=array(); $_size=count($arr); for($i=1;$i $_size;$i++) { if($arr[$i] =$k) { $x[] =$arr[$i];//小的放這邊 }else{ $y[] =$arr[$i];//大的放這邊。這樣子是從小到大排序,如果想從大到小返回,那么調換位置與$x[] =$arr[$i];的位置即可 //得到分割看來左右兩邊的數據 $x= quickSort($x);//左邊的數據,對這些數據再次使用分割法排序,返回的結果就是排序后的數據 $y= quickSort($y);//右邊的數據 returnarray_merge($x,array($k),$y); }else{ return$arr;不正確之處,歡迎指正!代碼備份://大體思路:由于是二維數組。所以先得到指定key的所有值。也就是轉換為一維數組了。不過這個一維數組的key要使用二維數組的key。這樣子一維數組排序后,方便對應到二維數組中去。就是靠這個key。一維數組如下:array('1'= 'a','4'= ''b','3'= 'c','5'= 'd');1,2,4這些key值,到時候就是對應到里面去的證據思考,如果還要加一個條件呢比如像sql那樣子的:order by a,b,c當a字段的值都相等的情況下,就啟用b字段進行排序。如果還是相等,則啟用c字段進行排序。$keys = array();$keys['gg'] = '8.9';$keys[1] = '8.8';$keys[5] = '7.5';asort($keys);//排序有個特點,原來的key值不會改變的。只是把位置換一下。我之前以為是調換了key值。這樣子,0,1,2,3,4reset($keys);var_dump($keys); * +------------------------------------------------------- * 快速排序 * @author wangtao 2015.6.10 * +------------------------------------------------------- * @param $arr 要排序的數組,二維數組。對應就是數據庫中的多行數據 array( * 0= array("字段1"= '','字段2'= ''...) * 1= array("字段1"= '','字段2'= ''...) * 2= array("字段1"= '','字段2'= ''...) * @param $key_field 按照哪個字段進行排序 * @param $sort_type = asc or desc 排序方式。從小大到大,還是從大到小 * +------------------------------------------------------- * return 按照指定排序后的一個新數組。原來的key仍然會保留 * 如:1= array("字段1"= '','字段2'= ''...),2= array("字段1"= '','字段2'= ''...) * 按照"字段2"排序后,key為2元素可能在前面前面了,但是key值不會被修改,會原樣保留 * +-------------------------------------------------------function quick_sort($arr, $key_field, $sort_type = "asc") { if (count($arr) 1) { //使用哪個字段排序,先得到該字段所有數據,目的是轉換成一維數組進行排序 $key_value_arr = array(); $return_arr = array(); //先判斷排序的字段是否存在,如果字段根本不存在,避免打亂原來數組的順序 foreach ($arr as $k = $v) { @ $key_value_arr[$k] = $v[$key_field]; //得到這個字段的值 //php內置函數實現了按降序還是升序排,但是只支持一維數組 if ($sort_type == 'desc') { arsort($key_value_arr); } else { asort($key_value_arr); reset($key_value_arr); foreach ($key_value_arr as $k = $v) { $return_arr[$k] = $arr[$k]; //得到行 //var_dump($return_arr); return $return_arr; } else { return $arr;$array = array(array('name'= '手機','brand'= '諾基亞','price'= 1050),array('name'= ' ','brand'= 'lenovo','price'= 4300),array('name'= '剃須刀','brand'= '飛利浦','price'= 3100),array('name'= '跑步機','brand'= '三和松石','price'= 4900),array('name'= '手表','brand'= '卡西歐','price'= 960),array('name'= '液晶電視','brand'= '索尼','price'= 6299),array('name'= '激光打印機','brand'= '惠普','price'= 1200),array('name'= '手機','brand'= '諾基亞','price'= 1050),var_dump(quickSort($array,'m'));//看對一個數組里面元素值都為空的怎么排序$row = array(0= null,1= null,2= null,3= null,asort($row);var_dump($row);//如果為空。則根據key值倒過來?/*返回的是array 3 = null 2 = null 1 = null 0 = null現在終于明白了,數據庫字段中是否保持null,對于排序是有影響的。結果就會影響展示效果。更多關于PHP相關內容感興趣的讀者可查看本站專題:《php排序算法總結》、《php面向對象程序設計入門教程》、《PHP數學運算技巧總結》、《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《PHP數組(Array)操作技巧大全》、《PHP數據結構與算法教程》、《php程序設計算法總結》、《php正則表達式用法總結》、及《php常見數據庫操作技巧匯總》希望本文所述對大家PHP程序設計有所幫助。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人福利网站在线观看11| 成人h猎奇视频网站| 亚洲精品久久久久久久久久久| 精品久久久久久久久久ntr影视| 一区二区三区四区视频| 欧美精品18videos性欧美| 欧美一区视频在线| 色偷偷9999www| 亚州av一区二区| 国产精品美女视频网站| 国内精品视频久久| 国产精品情侣自拍| 亚洲国产精品人人爽夜夜爽| 精品久久久av| 国产日韩精品综合网站| 国产精品中文久久久久久久| 国产精品白丝av嫩草影院| 久久精品99久久久久久久久| 亚洲精选中文字幕| 欧美一性一乱一交一视频| 91av视频在线免费观看| 欧美在线一区二区三区四| 亚洲国产精品久久久久| 亚洲天堂网站在线观看视频| 亚洲国产欧美在线成人app| 欧美高清自拍一区| 国产午夜一区二区| 欧美电影免费播放| 国产深夜精品福利| 国产精品99蜜臀久久不卡二区| 国产一区二区美女视频| 成人欧美一区二区三区黑人孕妇| 欧美激情中文字幕乱码免费| 欧美激情视频给我| 色yeye香蕉凹凸一区二区av| 国产成人精品免费久久久久| 欧美日韩视频免费播放| 日韩av在线资源| 精品国产31久久久久久| 亚洲免费小视频| 欧美一级在线亚洲天堂| 日韩精品久久久久| 欧美成人激情视频免费观看| 久久久视频精品| 日韩精品久久久久久久玫瑰园| 热re99久久精品国产66热| 欧美亚洲在线观看| 一本一道久久a久久精品逆3p| 亚洲欧美在线免费| 亚洲精品不卡在线| 欧美大全免费观看电视剧大泉洋| 中文字幕在线成人| 日韩在线视频观看正片免费网站| 欧美日韩国产中文精品字幕自在自线| 欧美在线视频一区| 欧美视频在线免费| 亚洲第一在线视频| 日本精品在线视频| 国产91露脸中文字幕在线| 91影视免费在线观看| 久久99国产精品自在自在app| 亚洲国内精品在线| 欧美成人精品在线视频| 国产91精品久久久久久| 亚洲电影免费观看高清完整版在线| 91精品91久久久久久| 久久久精品影院| 国语自产在线不卡| 国产精品电影网| 久久人人爽人人爽人人片av高清| 亚洲图片欧美午夜| 亚洲精选一区二区| 欧美一性一乱一交一视频| 欧美午夜久久久| 欧美午夜精品伦理| 亚洲18私人小影院| 久久久久久欧美| 中文字幕不卡av| 亚洲国产精品一区二区久| 亚洲图中文字幕| 亚洲欧洲高清在线| 69av成年福利视频| 成人久久久久久| 7777kkkk成人观看| 91理论片午午论夜理片久久| 国产精品免费看久久久香蕉| 午夜欧美大片免费观看| 中文字幕视频一区二区在线有码| 亚洲欧美国产一本综合首页| 热久久99这里有精品| 成人精品一区二区三区电影免费| 欧美激情xxxx| 国产精品自拍偷拍| 国模精品一区二区三区色天香| 中文字幕不卡在线视频极品| 日韩精品高清在线| 自拍视频国产精品| 国产日韩在线观看av| 精品国产视频在线| 欧美肥老太性生活视频| 日韩一区二区三区xxxx| 国产视频精品在线| 日韩精品极品视频| 国产精品劲爆视频| 日韩在线观看免费高清| 欧美巨猛xxxx猛交黑人97人| 国产成+人+综合+亚洲欧洲| 97在线视频国产| 亚洲国产精品久久久久久| 97成人精品视频在线观看| 亚洲国产小视频在线观看| 国产精品综合网站| 欧美日韩xxxxx| 欧美激情一区二区久久久| 国产精品永久免费| 日韩视频中文字幕| 色悠久久久久综合先锋影音下载| 亚洲大尺度美女在线| 国产91精品视频在线观看| 亚洲午夜精品久久久久久久久久久久| 亚洲色图13p| 亚洲人成在线免费观看| 亚洲国产成人在线视频| 九九九热精品免费视频观看网站| 日韩精品久久久久久福利| 岛国av一区二区| 欧美高清理论片| 亚洲国产精品电影在线观看| 国产成人高潮免费观看精品| 26uuu另类亚洲欧美日本一| 成人免费大片黄在线播放| 欧美极品xxxx| 亚洲人精选亚洲人成在线| www.99久久热国产日韩欧美.com| 国产精品嫩草影院久久久| 国产精品第一视频| 2020国产精品视频| 亚洲精选在线观看| 欧美黑人巨大xxx极品| 伊人久久久久久久久久久| 国产日韩欧美在线视频观看| 久久久久久中文| 亚洲欧美一区二区三区在线| 正在播放欧美一区| 亚洲第一免费播放区| 国产日韩精品综合网站| 米奇精品一区二区三区在线观看| 最近2019年手机中文字幕| 日韩在线精品一区| 国产精品免费久久久久影院| 琪琪亚洲精品午夜在线| 日韩在线观看免费网站| 欧美日韩国产精品一区二区不卡中文| 国产精品高潮呻吟久久av无限| 亚洲欧美国产精品va在线观看| 日韩av黄色在线观看| xxxx欧美18另类的高清| 欧美激情免费看| 午夜精品一区二区三区av| 97视频在线观看播放| 97人人模人人爽人人喊中文字| 91sao在线观看国产| 欧美激情喷水视频| 中文字幕av一区中文字幕天堂|