成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? PHP實現的貪婪算法實例
全站頭部文字 我要出現在這里
PHP實現的貪婪算法實例 806 2023-12-08   

本文實例講述了PHP實現的貪婪算法。分享給大家供大家參考,具體如下:

背景介紹:貪婪算法與數據結構知識庫算法可以說是離我們生活最近的一種算法,人總是貪婪的嘛,所以這種算法的設計是很符合人性的。之所以這么說,是因為人們會在生活中有意無意的使用貪婪算法來解決問題。最常見的就是找零錢了,每個人都沒學過該怎么找零錢,但在所有面額的錢都充足時,每個人都會找出同樣組合來湊夠需要的錢。其實這里面就是貪婪算法在起作用。

設計思路:貪婪法的設計思路可以從兩方面來理解,即直觀上和數學上。從直觀上理解貪婪算法就是用最快的方法來解決問題。在這里面“快”是主要目標,例如上面找零錢的例子,假如你要找的零錢為6.6元。那首先要拿一張5元的,因為這可以使你湊的錢增長最快。如果人民幣有6元的面額那你肯定會選6元的而不是拿兩張別的來湊6元;從數學上來理解貪婪算法就是在做判斷時以當前最優解為目標,類似于最優化中的最速下降法。這種方法的好處是解題速度極快,基本上是一次歷遍就可以完成。

算法缺陷:正如做人不能太貪婪一樣,貪婪算法本身有著致命的缺陷,這使得其應用背景收到了很多限制。因為算法是取的局部最優解,沒有考慮以后的問題。這就像一個自私自利的人一樣,雖然短時間內可以獲得一些利益,但長期以往,很難會有大的成就。當然,社會很復雜,也許會有人一直自私下去而生活的還不錯。這體現在算法上就是在一些情況下(具體下面會提到),貪婪算法是可以得到最優解的,這對于算法設計來說當然是好事。

/*
* 貪婪算法
* $arr   array  處理數組
* $volume  int   盒子容量
*/
function greedy($arr, $volume){
    $box = array();
    $boxNum = 0;
    $num = count( $arr );
    for ($i = 0; $i < $num; $i++) {
      $boxCode = true;
      for ($j = 0; $j < $boxNum; $j++) {
        if ($arr[$i] + $box[$j]['v'] <= $volume) {
          $box[$j]['v'] += $arr[$i];
          $box[$j]['k'][] = $i;
          $boxCode = false;
          break;
        }
      }
      if ($boxCode) {
        $box[$boxNum]['v'] = $arr[$i];
        $box[$boxNum]['k'][] = $i;
        $boxNum++;
      }
    }
    return $box;
}

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《PHP基本語法入門教程》、《php面向對象程序設計入門教程》、《php字符串(string)用法總結》及《php程序設計算法總結》

希望本文所述對大家PHP程序設計有所幫助。


主站蜘蛛池模板: 爱我中华广场舞| 故乡之恋简谱| 天天操免费视频| 风花电影完整版免费观看| 数字记忆法编码100| 小小少年电影简介| 韩宝仪个人简历| 广西地图全图可放大| 国土防线| 脸庞村庄| 北京卫视今天节目预告| 美少女战士变身| 激情豪放女| 后位子宫怎么样容易怀孕| 1983年《魔》| 无耻之徒阿曼达| 圆的认识评课| 四大纸飞机的折法| 抖音生活| 婷婷sese| 大秦帝国第一部免费观看46集| 贵阳银行客服电话24小时人工服务| 肮脏性感的人| 《感恩的心》儿童朗诵| free hd xxxx moms movie777| 黑玫瑰演员表| 远方的故乡简谱| 丧尸童子军| 电视剧狙击手免费全集播放| 韩孝周超异能族| 李莉莉| 小绵羊男星是谁| 李子京| 爱你电视剧演员表| 女孩们电影| 王音棋的个人简历| 国家宝藏之觐天宝匣| 无常电影| 维罗尼卡| 喜迎20大文艺汇演主持词| 电影《exotica》完整版观看|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103