news 2026/6/23 17:06:22

贪心算法:用局部最优解迈向全局最优的艺术

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
贪心算法:用局部最优解迈向全局最优的艺术

贪心算法:用局部最优解迈向全局最优的艺术

什么是贪心算法?

贪心算法(Greedy Algorithm)是一种在每一步选择中都采取在当前状态下最好或最优的选择,从而希望导致结果是全局最好或最优的算法策略。它不像动态规划那样考虑所有可能的子问题,而是局部最优,希望全局最优

贪心算法的适用场景

贪心算法适用于满足以下两个条件的问题:

  1. 贪心选择性质:局部最优选择能导致全局最优解

  2. 最优子结构:问题的最优解包含其子问题的最优解

经典问题与C++实现

1. 找零钱问题(硬币问题)

问题描述:给定不同面额的硬币和一个总金额,求最少硬币数。

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

int coinChangeGreedy(vector<int>& coins, int amount) {
// 从大到小排序硬币
sort(coins.rbegin(), coins.rend());

int count = 0;
for (int coin : coins) {
while (amount >= coin) {
amount -= coin;
count++;
}
}

return (amount == 0) ? count : -1;
}

int main() {
vector<int> coins = {1, 5, 10, 20, 50, 100};
int amount = 123;

int result = coinChangeGreedy(coins, amount);
if (result != -1) {
cout << "找零 " << amount << " 元需要最少 " << result << " 枚硬币" << endl;
} else {
cout << "无法找零" << endl;
}

return 0;
}

2. 区间调度问题

问题描述:给定多个会议的开始和结束时间,求最多能参加多少个不冲突的会议。

#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;

struct Interval {
int start;
int end;
};

bool compare(Interval a, Interval b) {
return a.end < b.end; // 按结束时间升序排序
}

int maxMeetings(vector<Interval>& meetings) {
if (meetings.empty()) return 0;

// 按结束时间排序
sort(meetings.begin(), meetings.end(), compare);

int count = 1; // 第一个会议总是可以参加
int lastEnd = meetings[0].end;

for (int i = 1; i < meetings.size(); i++) {
if (meetings[i].start >= lastEnd) {
count++;
lastEnd = meetings[i].end;
}
}

return count;
}

int main() {
vector<Interval> meetings = {
{1, 3}, {2, 4}, {3, 6}, {5, 7}, {8, 9}
};

int result = maxMeetings(meetings);
cout << "最多可以参加 " << result << " 个会议" << endl;

return 0;
}

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

分布式消息队列kafka【四】—— 消费者进阶提升

分布式消息队列kafka【四】—— 消费者进阶提升 文章目录分布式消息队列kafka【四】—— 消费者进阶提升kafka消费者与消费者组的概念详解kafka之消费者与消费者组传统消息中间件投递模式kafka的消息中间件模型kafka消费者点对点模型与发布订阅模型实现topic常量生产者点对点模…

作者头像 李华
网站建设 2026/6/23 16:21:43

HunyuanVideo-Foley实战教程:结合HTML与JavaScript实现实时音效预览

HunyuanVideo-Foley实战教程&#xff1a;结合HTML与JavaScript实现实时音效预览 在短视频和直播内容井喷的今天&#xff0c;观众对视频“沉浸感”的要求早已超越画质本身。一个脚步声是否清脆、玻璃碎裂是否逼真、环境音是否自然&#xff0c;往往决定了作品的专业度。但传统音效…

作者头像 李华
网站建设 2026/6/23 13:15:11

5步部署WVP-GB28181-Pro:开源国标平台的终极指南

5步部署WVP-GB28181-Pro&#xff1a;开源国标平台的终极指南 【免费下载链接】wvp-GB28181-pro 项目地址: https://gitcode.com/GitHub_Trending/wv/wvp-GB28181-pro 当企业需要快速搭建跨品牌监控系统时&#xff0c;往往面临设备兼容性差、部署复杂等痛点。WVP-GB2818…

作者头像 李华
网站建设 2026/6/19 16:31:25

X-TRACK 3D打印外壳DIY实战:从零打造专业级GPS自行车码表

X-TRACK 3D打印外壳DIY实战&#xff1a;从零打造专业级GPS自行车码表 【免费下载链接】X-TRACK A GPS bicycle speedometer that supports offline maps and track recording 项目地址: https://gitcode.com/gh_mirrors/xt/X-TRACK 你是否曾经为市售自行车码表功能单一…

作者头像 李华
网站建设 2026/6/23 0:43:58

浏览器串口助手终极指南:零安装调试嵌入式设备

浏览器串口助手终极指南&#xff1a;零安装调试嵌入式设备 【免费下载链接】SerialAssistant A serial port assistant that can be used directly in the browser. 项目地址: https://gitcode.com/gh_mirrors/se/SerialAssistant 在物联网开发和嵌入式系统调试中&#…

作者头像 李华
网站建设 2026/6/21 9:09:37

gpt-oss-20b与ChatGLM-6B在中文场景下的对比实验

gpt-oss-20b与ChatGLM-6B在中文场景下的对比实验 在一台配备RTX 3060、内存16GB的普通台式机上&#xff0c;能否跑起真正“能用”的大模型&#xff1f;这不仅是个人开发者关心的问题&#xff0c;更是企业私有化部署智能系统时最现实的考量。随着数据安全法规趋严和边缘计算需求…

作者头像 李华