当前位置: 首页 > news >正文

【JavaScript 算法】贪心算法:局部最优解的构建

在这里插入图片描述

🔥 个人主页:空白诗

在这里插入图片描述

文章目录

    • 一、贪心算法的基本概念
      • 贪心算法的适用场景
    • 二、经典问题及其 JavaScript 实现
      • 1. 零钱兑换问题
      • 2. 活动选择问题
      • 3. 分配问题
    • 三、贪心算法的应用
    • 四、总结

在这里插入图片描述

贪心算法(Greedy Algorithm)是一种逐步构建解决方案的方法。在每一步选择中,贪心算法总是选择在当前看来最优的选择,希望通过这些局部最优选择最终能构建出全局最优解。贪心算法的特点是简单高效,但它并不总能保证得到最优解。


一、贪心算法的基本概念

贪心算法的核心思想是每一步都选择当前最优的决策,不考虑未来的影响。贪心算法的基本步骤通常包括以下几个:

  1. 选择:选择当前最优的选项。
  2. 验证:验证当前选择是否可行(通常包括是否满足约束条件)。
  3. 构建:将当前选择加入到最终的解决方案中。

贪心算法的适用场景

贪心算法通常适用于以下场景:

  1. 最小生成树:如Kruskal和Prim算法。
  2. 最短路径问题:如Dijkstra算法。
  3. 区间调度问题:如选择最多的不重叠区间。

二、经典问题及其 JavaScript 实现

1. 零钱兑换问题

假设我们有几种不同面值的硬币,1元、2元和5元。我们希望用最少数量的硬币来凑出某个金额。

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

/*** 求最少数量的硬币组合* @param {number[]} coins - 硬币面值数组* @param {number} amount - 总金额* @returns {number} - 最少硬币数量,如果无法凑出总金额返回 -1*/
function coinChange(coins, amount) {// 硬币面值从大到小排序coins.sort((a, b) => b - a);let count = 0;for (let coin of coins) {// 尽量使用当前面值最大的硬币let num = Math.floor(amount / coin);count += num;amount -= num * coin;// 如果总金额为 0,直接返回if (amount === 0) return count;}// 如果无法凑出总金额,返回 -1return -1;
}// 示例:用1元、2元和5元凑出11元的最少硬币数量
console.log(coinChange([1, 2, 5], 11)); // 输出 3 (5 + 5 + 1)

2. 活动选择问题

假设我们有一组活动,每个活动有开始时间和结束时间。我们希望选择尽可能多的活动,使得它们互不重叠。

问题描述:给定一组活动,选择尽可能多的不重叠活动。

/*** 求最多的不重叠活动数量* @param {number[][]} activities - 活动的开始和结束时间数组* @returns {number} - 最多不重叠活动数量*/
function maxActivities(activities) {// 按照活动结束时间排序activities.sort((a, b) => a[1] - b[1]);let count = 0;let end = 0;for (let activity of activities) {if (activity[0] >= end) {// 选择当前活动count++;end = activity[1];}}return count;
}// 示例:选择最多的不重叠活动
console.log(maxActivities([[1, 3], [2, 4], [3, 5], [0, 6], [5, 7], [8, 9], [5, 9]]));
// 输出 4 (选择活动 [1, 3], [3, 5], [5, 7], [8, 9])

3. 分配问题

假设我们有一组任务和一组工人,每个工人能完成的任务数量有限。我们希望尽可能多地完成任务。

问题描述:给定任务和工人的能力,尽可能多地分配任务。

/*** 求最多分配任务数量* @param {number[]} tasks - 任务难度数组* @param {number[]} workers - 工人能力数组* @returns {number} - 最多分配任务数量*/
function maxTaskAssignment(tasks, workers) {// 任务和工人分别排序tasks.sort((a, b) => a - b);workers.sort((a, b) => a - b);let taskIndex = 0;let workerIndex = 0;let count = 0;while (taskIndex < tasks.length && workerIndex < workers.length) {if (workers[workerIndex] >= tasks[taskIndex]) {// 分配任务给当前工人count++;taskIndex++;}workerIndex++;}return count;
}// 示例:尽可能多地分配任务
console.log(maxTaskAssignment([1, 2, 3], [3, 2, 1])); // 输出 3 (每个工人完成一个任务)

三、贪心算法的应用

贪心算法在实际开发中有广泛的应用,常见的应用场景包括:

  1. 图算法:最小生成树、最短路径问题。
  2. 活动选择:选择最多的不重叠活动。
  3. 任务分配:将任务尽可能多地分配给工人。
  4. 区间覆盖:用最少数量的区间覆盖所有点。

四、总结

贪心算法是一种通过局部最优选择构建全局最优解的方法。虽然它不总能保证得到最优解,但在许多实际问题中表现良好。通过理解和应用贪心算法,我们可以有效地解决许多复杂的优化问题。希望通过本文的介绍,大家能够更好地理解和应用贪心算法。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • JVM(day2)经典垃圾收集器
  • C++:类的定义和实例化
  • 云微客如何实现低成本快速获客?AI矩阵来传播
  • Linux-交换空间(Swap)管理
  • 第三章 OSPF高级
  • JuiceFS缓存特性
  • GitHub私有派生仓库(fork仓库) | 派生仓库改为私有
  • 尚硅谷大数据技术-数据湖Hudi视频教程-笔记03【Hudi集成Spark】
  • uni-app学习HBuilderX学习-微信开发者工具配置
  • 前端Canvas入门——用canvas写五子棋?
  • 【python学习】爬虫中常使用的urllib和requests库的的背景、定义、特点、功能、代码示例以及两者的区别
  • 数据结构小测试:排序算法
  • OpenCv 如何在 Java 中使用
  • 数据结构课程设计:源代码(C)客房信息管理系统
  • 【Qt+opencv】基础的图像绘制
  • ----------
  • C学习-枚举(九)
  • ES10 特性的完整指南
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • ES6系列(二)变量的解构赋值
  • JavaScript设计模式之工厂模式
  • leetcode98. Validate Binary Search Tree
  • LeetCode算法系列_0891_子序列宽度之和
  • node 版本过低
  • PyCharm搭建GO开发环境(GO语言学习第1课)
  • Stream流与Lambda表达式(三) 静态工厂类Collectors
  • web标准化(下)
  • win10下安装mysql5.7
  • 爱情 北京女病人
  • 飞驰在Mesos的涡轮引擎上
  • 构建工具 - 收藏集 - 掘金
  • 两列自适应布局方案整理
  • 判断客户端类型,Android,iOS,PC
  • 使用阿里云发布分布式网站,开发时候应该注意什么?
  • 网络应用优化——时延与带宽
  • 我看到的前端
  • 小而合理的前端理论:rscss和rsjs
  • 阿里云移动端播放器高级功能介绍
  • 好程序员web前端教程分享CSS不同元素margin的计算 ...
  • ​2020 年大前端技术趋势解读
  • (2024,LoRA,全量微调,低秩,强正则化,缓解遗忘,多样性)LoRA 学习更少,遗忘更少
  • (差分)胡桃爱原石
  • (剑指Offer)面试题34:丑数
  • (一)springboot2.7.6集成activit5.23.0之集成引擎
  • .NET COER+CONSUL微服务项目在CENTOS环境下的部署实践
  • .net framework 4.0中如何 输出 form 的name属性。
  • .NET 的静态构造函数是否线程安全?答案是肯定的!
  • .NET+WPF 桌面快速启动工具 GeekDesk
  • .net6解除文件上传限制。Multipart body length limit 16384 exceeded
  • .net通用权限框架B/S (三)--MODEL层(2)
  • @Bean, @Component, @Configuration简析
  • @html.ActionLink的几种参数格式
  • @PreAuthorize与@Secured注解的区别是什么?
  • @synthesize和@dynamic分别有什么作用?
  • [ Python ]使用Charles对Python程序发出的Get与Post请求抓包-解决Python程序报错问题