PHP如何使用贪婪算法解决0-1背包问题-创新互联

这篇文章主要为大家展示了“PHP如何使用贪婪算法解决0-1背包问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“PHP如何使用贪婪算法解决0-1背包问题”这篇文章吧。

公司主营业务:做网站、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出南召免费做网站回馈大家。

具体分析如下:

贪心算法解决0-1背包问题,全局最优解通过局部最优解来获得!比动态规划解决背包问题更灵活!

//0-1背包贪心算法问题
class tanxin{
  public $weight;
  public $price;
  public function __construct($weight=0,$price=0)
  {
    $this->weight=$weight;
    $this->price=$price;
  }
}
//生成数据
$n=10;
for($i=1;$i<=$n;$i++){
  $weight=rand(1,20);
  $price=rand(1,10);
  $x[$i]=new tanxin($weight,$price);
}
//输出结果
function display($x)
{
  $len=count($x);
  foreach($x as $val){
    echo $val->weight,' ',$val->price;
    echo '
';   } } //按照价格和重量比排序 function tsort(&$x) {   $len=count($x);   for($i=1;$i<=$len;$i++)   {     for($j=1;$j<=$len-$i;$j++)     {        $temp=$x[$j];       $res=$x[$j+1]->price/$x[$j+1]->weight;       $temres=$temp->price/$temp->weight;       if($res>$temres){         $x[$j]=$x[$j+1];         $x[$j+1]=$temp;       }     }   }  } //贪心算法 function tanxin($x,$totalweight=50) {   $len=count($x);   $allprice=0;   for($i=1;$i<=$len;$i++){     if($x[$i]->weight>$totalweight) break;     else{       $allprice+=$x[$i]->price;       $totalweight=$totalweight-$x[$i]->weight;     }   }   if($i<$len) $allprice+=$x[$i]->price*($totalweight/$x[$i]->weight);   return $allprice; } tsort($x);//按非递增次序排序 display($x);//显示 echo '0-1背包最优解为:'; echo tanxin($x);

以上是“PHP如何使用贪婪算法解决0-1背包问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联行业资讯频道!


当前名称:PHP如何使用贪婪算法解决0-1背包问题-创新互联
转载源于:http://pcwzsj.com/article/diigcj.html