news 2026/5/7 2:03:54

贪心算法专题(一):局部最优的魔力——“抠门”的「分发饼干」

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
贪心算法专题(一):局部最优的魔力——“抠门”的「分发饼干」

哈喽各位,我是前端小L。

欢迎来到贪心算法专题第一篇! 贪心算法没有固定的套路模板(不像回溯有backtrack模板,DP 有dp数组)。贪心的核心在于策略

我们通过“分发饼干”这道题来感受一下:假设你是一位精打细算的家长,手里有一堆大小不一的饼干,面前站着一堆胃口大小不一的孩子。你的目标是喂饱尽可能多的孩子,但为了不浪费,你应该怎么分?

力扣 455. 分发饼干

https://leetcode.cn/problems/assign-cookies/

题目分析:

  • 输入

    • g(greed factor):数组,表示每个孩子的胃口值(最小能吃饱的量)。

    • s(size):数组,表示每块饼干的大小。

  • 规则:如果s[j] >= g[i],我们可以把饼干j给孩子i,这个孩子就满足了。

  • 目标:尽可能满足更多的孩子。

核心思维:大饼干喂大胃口,还是小饼干喂小胃口?

如果我们随便分:

  • 拿一块超级大的饼干,喂给一个胃口很小的孩子 ->浪费(大饼干本可以喂给大胃口的孩子)。

  • 拿一块很小的饼干,喂给一个胃口很大的孩子 ->无效(孩子吃不饱,饼干也没了)。

贪心策略一(小喂小):优先用最小的饼干,去喂胃口最小的孩子。

  • 如果这块最小的饼干能满足他,那就给他(局部最优:既喂饱了一个,又保留了较大的饼干给后面)。

  • 如果这块饼干连最小胃口都满足不了,那这块饼干就是废的,谁也喂不饱,丢掉(也就是换下一块大一点的)。

贪心策略二(大喂大):优先用最大的饼干,去喂胃口最大的孩子。

  • 如果最大的饼干能满足最大的胃口,那就给他。

  • 如果满足不了,说明这个大胃口的孩子谁也救不了,放弃他,看下一个胃口稍微小一点的孩子。

这两种策略都是对的!为了便于实现,我们通常选择**“先排序,再匹配”**。

算法流程 (策略一:小饼干先喂小胃口)

  1. 排序:将孩子的胃口g和饼干大小s都从小到大排序。

  2. 双指针遍历

    • child指向第 0 个孩子。

    • cookie指向第 0 块饼干。

  3. 循环判断

    • 如果s[cookie] >= g[child]

      • 太好了,这块饼干正好(或勉强)能喂饱这个孩子。

      • child++(换下一个孩子)。

      • cookie++(换下一块饼干)。

    • 如果s[cookie] < g[child]

      • 这块饼干太小了,连胃口最小的孩子都满足不了。

      • cookie++(换一块更大的试试,孩子原地不动)。

  4. 结束child的数值就是被满足的孩子总数。

代码实现 (C++)

C++

#include <vector> #include <algorithm> using namespace std; class Solution { public: int findContentChildren(vector<int>& g, vector<int>& s) { // 1. 贪心的前提通常是“有序” sort(g.begin(), g.end()); sort(s.begin(), s.end()); int child = 0; int cookie = 0; // 2. 遍历饼干和孩子 while (child < g.size() && cookie < s.size()) { // 如果当前的饼干能满足当前的孩子 if (s[cookie] >= g[child]) { child++; // 孩子吃饱了,换下一个 } // 无论能不能满足,这块饼干都“消耗”了 // (如果满足了,被吃了;如果不满足,它太小了没用,被跳过) cookie++; } return child; } };

深度复杂度分析

  • 时间复杂度:O(N log N + M log M)

    • 瓶颈在于排序gs的排序分别需要N log NM log M

    • 后面的双指针遍历只需要O(N + M)

  • 空间复杂度:O(1)(或 O(log N) 取决于排序算法的实现)

    • 我们只需要几个变量,不需要额外的数组空间。

总结:贪心的第一准则

今天这道题虽然简单,但它揭示了贪心算法最重要的两个特征:

  1. 排序:大多数贪心问题,都需要在有序的数据上才能进行“最优选择”。如果题目没给有序数组,你往往需要先sort

  2. 局部最优 -> 全局最优

    • 局部最优:这块饼干哪怕只比孩子的胃口大一点点,我也给它用了,绝不浪费更大的饼干。

    • 全局最优:最后喂饱的孩子最多。

这种**“没有后效性”**(现在的选择不会影响未来的可行性,只会让未来更好做)是贪心算法生效的基础。

下一题预告: 如果情况稍微复杂一点,我们面对的不是静态的饼干,而是一个波动的序列。我们要在一个忽高忽低的序列中,统计“峰值”和“谷值”的变化次数(摆动序列)。这道题将展示如何通过**忽略“平坡”**这一局部贪心策略来解决问题。

下期见!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 7:58:40

2025年AI面试权威测评:HR招聘提效TOP榜单与选型指南

随着人工智能技术在人力资源领域的深度渗透&#xff0c;AI 面试已从 “可选工具” 升级为 “招聘刚需”&#xff0c;2025 年更是迎来 AI 面试 2.0 时代的全面爆发 —— 招聘不再局限于 “评估现有能力”&#xff0c;更聚焦 “挖掘未来潜力”&#xff0c;降本、提效、精准识人成…

作者头像 李华
网站建设 2026/5/5 17:42:33

STM32F103C8T6微控制器实战指南:从选型到项目开发全解析

STM32F103C8T6微控制器实战指南&#xff1a;从选型到项目开发全解析 【免费下载链接】STM32F103C8T6中文数据手册 本资源文件提供了STM32F103C8T6微控制器的中文数据手册。STM32F103C8T6是一款基于ARM Cortex-M3内核的32位微控制器&#xff0c;具有高性能、低功耗和低电压特性&…

作者头像 李华
网站建设 2026/5/3 12:00:20

仿宋_GB2312字体下载:MAC用户的终极中文排版解决方案

在数字文档排版和平面设计领域&#xff0c;选择一款合适的中文字体至关重要。今天为您推荐的仿宋_GB2312字体资源下载项目&#xff0c;是专为MAC操作系统设计的国家标准编码字体&#xff0c;能够满足您对中文文档排版的高标准要求。无论是撰写论文、设计海报还是制作专业报告&a…

作者头像 李华
网站建设 2026/5/5 9:35:11

《Nature Communications》发表狄拉克涡旋拓扑光子晶体光纤首次实验实现

前言摘要近日&#xff0c;我国科研团队在顶级期刊《自然通讯》上发表了一项具有里程碑意义的研究&#xff1a;全球首次实验制备出“狄拉克涡旋拓扑光子晶体光纤”(https://doi.org/10.1038/s41467-025-65222-z)。该光纤融合拓扑光子学前沿理论与光纤制备技术&#xff0c;实现宽…

作者头像 李华
网站建设 2026/5/1 20:47:37

快速掌握PSCAD:电力系统仿真实战完整指南

快速掌握PSCAD&#xff1a;电力系统仿真实战完整指南 【免费下载链接】乐健老师PSCAD培训PPT下载 乐健老师PSCAD培训PPT下载 项目地址: https://gitcode.com/open-source-toolkit/f9db7 解决电力系统仿真的核心痛点 电力系统仿真作为电气工程领域的核心技术&#xff0c…

作者头像 李华
网站建设 2026/5/4 20:31:53

Docker容器技术终极入门:3步解决环境部署难题

Docker容器技术终极入门&#xff1a;3步解决环境部署难题 【免费下载链接】udemy-docker-mastery Docker Mastery Udemy course to build, compose, deploy, and manage containers from local development to high-availability in the cloud 项目地址: https://gitcode.com…

作者头像 李华