【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;
    }

    // 如果无法凑出总金额,返回 -1
    return -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. 区间覆盖:用最少数量的区间覆盖所有点。

四、总结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/803077.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【前端6*】表格-表单2(弹窗在父组件)父子组件调用 vue element-ui

vue element-ui 中表单弹框的使用 写在最前面一、完整代码1、&#xff08;子组件&#xff09;E:\ui\参考代码\demo-new\src\components\detail.vue2、&#xff08;父组件&#xff09;E:\ui\参考代码\demo-new\src\views\Home.vue 二、小结 &#x1f308;你好呀&#xff01;我是…

Qt Style Sheets-入门

Qt 样式表是一种强大的机制&#xff0c;允许您自定义小部件的外观&#xff0c;这是在通过子类化QStyle已经可行的基础上的补充。Qt 样式表的概念、术语和语法在很大程度上受到 HTML级联样式表 (CSS)的启发&#xff0c;但适用于小部件的世界。 概述 样式表是文本规范&#xff0…

手机数据恢复技巧:适用于 Android 的恢复应用程序

发现自己意外删除了 Android 设备上的照片&#xff0c;这让人很痛苦。这些照片可能是值得纪念的文件&#xff0c;会让您想起一些难忘的回忆。删除它们后&#xff0c;您知道如何恢复它们。在这种情况下&#xff0c;您需要使用 Android 的照片恢复应用程序。 无论您需要直接从 A…

【Python基础教程】制作一个宿舍管理系统,数据库宿舍管理系统代码!(完整版,附源码)

今天我们一起学习一个新的小案例——宿舍管理系统。主要涉及列表、字典的初始化、增加、删除、修改和查询操作&#xff0c;以及函数的定义和调用。 一、需求&#xff1a; 有操作指引界面&#xff0c;显示操作号 能添加一个新的入住学生信息&#xff0c;包括学生姓名、宿舍号床…

蓝桥杯14小白月赛题解

直接输出pi/ti,for遍历 #include <iostream> using namespace std; #define int long long int a,b,c ; double t1.00; signed main() {cin>>a;int an0;for(int i1;i<a;i){cin>>b>>c;if(t>c*1.00/b){tc*1.00/b;ani;} }cout<<an<<e…

搭建hadoop+spark完全分布式集群环境

目录 一、集群规划 二、更改主机名 三、建立主机名和ip的映射 四、关闭防火墙(master,slave1,slave2) 五、配置ssh免密码登录 六、安装JDK 七、hadoop之hdfs安装与配置 1)解压Hadoop 2)修改hadoop-env.sh 3)修改 core-site.xml 4)修改hdfs-site.xml 5) 修改s…

使用GPT3.5,LangChain,FAISS和python构建一个本地知识库

引言 介绍本地知识库的概念和用途 在现代信息时代&#xff0c;我们面临着海量的数据和信息&#xff0c;如何有效地管理和利用这些信息成为一项重要的任务。本地知识库是一种基于本地存储的知识管理系统&#xff0c;旨在帮助用户收集、组织和检索大量的知识和信息。它允许用户…

深度学习驱动智能超材料设计与应用

在深度学习与超材料融合的背景下&#xff0c;不仅提高了设计的效率和质量&#xff0c;还为实现定制化和精准化的治疗提供了可能&#xff0c;展现了在材料科学领域的巨大潜力。深度学习可以帮助实现超材料结构参数的优化、电磁响应的预测、拓扑结构的自动设计、相位的预测及结构…

软件测试——非功能测试

工作职责&#xff1a; 1.负责产品系统测试&#xff0c;包括功能测试、性能测试、稳定性测试、用户场景测试、可靠性测试等。 2.负责测试相关文档的编写&#xff0c;包括测试计划、测试用例、测试报告等。 3.负责自动化测试框架、用例的维护。 岗位要求&#xff1a; 1.熟练…

数据可视化在智慧医疗中的重要应用

在现代智慧医疗的推动下&#xff0c;数据可视化技术正日益成为医疗领域的重要工具。通过将复杂的医疗数据转换为直观的图表和图形&#xff0c;数据可视化不仅提升了医疗服务的效率&#xff0c;还极大地改善了患者的就医体验。 在智慧医疗中&#xff0c;数据可视化首先在电子病历…

知识图谱和 LLM:利用Neo4j驾驭大型语言模型(探索真实用例)

这是关于 Neo4j 的 NaLLM 项目的一篇博客文章。这个项目是为了探索、开发和展示这些 LLM 与 Neo4j 结合的实际用途。 2023 年,ChatGPT 等大型语言模型 (LLM) 因其理解和生成类似人类的文本的能力而风靡全球。它们能够适应不同的对话环境、回答各种主题的问题,甚至模拟创意写…

实时系统Preempt RT与Xenomai之争!谁更主流,谁更实时

版权声明&#xff1a;本文主要内容基于“北京盟通科技有限公司”授权提供的文件&#xff0c;由“创龙科技”进行整理得出。感谢“盟通科技”的慷慨支持&#xff0c;让更多人了解Linux系统的“实时拓展”选择知识。 选择争论一直存在 大家知道EtherCAT是实时现场总线技术&…

Java中使用加密盐

0 前言 众所周知&#xff0c;密码肯定不能用明文存储。 之前一直使用MD5进行加密&#xff0c;现在才知道有彩虹表这回事。所以记录一下对应的处理方式&#xff1a;加密盐。 1 彩虹表 例如用MD5加密&#xff0c;随便没法破解&#xff0c;但是有些常用的字符被收集到彩虹表里…

OSU!题解(概率dp)

题目&#xff1a;OSU! - 洛谷 思路&#xff1a; 设E()表示截止到i所获得的分数&#xff1b; 对于到i点的每一个l&#xff0c;如果第i1点为1&#xff0c;那么会新增分数3*l^23*l1; 就有递推公式方程&#xff1a; E()E()p[i1]p*(3*l^23*l1);(p代表截止到i获得长度l的概率)&a…

关于mybatis中语法的错误记录

大家注意再写mybatis时候的逗号&#xff0c;虽然不起眼&#xff0c;但是会一直报错&#xff0c;最后一个字段不需要逗号&#xff0c;其余字段全部需要逗号。

【个人笔记】685. 冗余连接 II 的解释(并查集)

一棵树有n个点和n条边&#xff0c;返回一条能删除的边&#xff0c;使得剩下的图是有 n 个节点的有根树。 解释&#xff1a; 注意不冗余的有根树的特性&#xff01;**根节点入度为0&#xff0c;其余结点只有一个入度&#xff01;**所以冗余的两种情况如下&#xff1a; &#xff…

Vue3项目基于Axios封装request请求

在 Vue 3 的项目开发中&#xff0c;使用 Axios 进行 HTTP 请求是非常常见的作法&#xff0c;为了更方便开发者更高效的进行代码编写和项目的维护&#xff0c;可以通过再次封装 Axios 来实现。 在本文中&#xff0c;博主将详细指导你如何在自己的 Vue 3 项目中使用 Axios 二次封…

Vue学习---vue cli 项目创建

使用的编辑工具webStorm 创建例子: hello vue create hello 选择 vue3 进行创建 运行 npm run serve 测试访问&#xff1a;http://localhost:8080 改动内容重新编译&#xff1a; npm run build dist 目录就是编译后的可运行内容

客流统计系统优化景区服务流程,增强游客满意度

在当今旅游业蓬勃发展的时代&#xff0c;景区面临着越来越多的挑战和机遇。如何提供更优质、更高效的服务&#xff0c;满足游客日益增长的需求&#xff0c;成为了景区管理者们关注的焦点。客流统计系统作为一种创新的技术手段&#xff0c;正逐渐成为优化景区服务流程、增强游客…

windows 打包pyd文件

1.新建一个py文件&#xff0c;myunit.py&#xff0c;里面的代码是: class Adder: def __init__(self, a, b): self.a a self.b b def add(self): return self.a self.b 2.新建一个py文件&#xff0c;setup.py&#xff0c;里面的代码是: from setuptools import setup fro…