贪心算法
贪心算法(英语:greedy algorithm),又称贪婪算法,是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的算法。比如在旅行推销员问题中,如果旅行员每次都选择最近的城市,那这就是一种贪心算法。
贪心算法在有最优子结构的问题中尤为有效。最优子结构的意思是局部最优解能决定全局最优解。简单地说,问题能够分解成子问题来解决,子问题的最优解能递推到最终问题的最优解。
贪心法一般不能得到我们所要求的答案。一旦一个问题可以通过贪心法来解决,那么贪心法一般是解决这个问题的最好办法。由于贪心法的高效性以及其所求得的答案比较接近最优结果,贪心法也可以用作辅助算法或者直接解决一些要求结果不特别精确的问题。在不同情况,选择最优的解,可能会导致辛普森悖论(Simpson's Paradox),不一定出现最优的解。
思路
- 创建数学模型来描述问题
- 把求解的问题分成若干个子问题。
- 对每一子问题求解,得到子问题的局部最优解
- 把子问题的解局部最优解合成原来解问题的一个解。
题目
题目描述:每个孩子都有一个满足度,每个饼干都有一个大小,只有饼干的大小大于一个孩子的满足度,该孩子才会获得满足。求解最多可以获得满足的孩子数量。
代码
/**
* 贪心算法
* @param Integer[] $kids 小孩
* @param Integer[] $cookies 饼干
* @return Integer $k 满足数量
*/
function findContentChildren($kids, $cookies) {
sort($kids);//排序饼干
sort($cookies);//排序小孩满足度
$k = $c = 0;
//饼干数量小于$k ,并且小孩数量小于$c
while($k<count($kids) && $c<count($cookies)){
//如果满足了
if($kids[$k] <= $cookies[$c]){
$k++;
}
$c++;
}
return $k;
}
$kids = [20,20,20,30,45,60];
$cookies = [20,20,20,30,45,60];
echo '<pre>';
print_r(findContentChildren($kids,$cookies));