贪心算法和动态规划
目录
一、简介
二、贪心算法案例:活动选择问题
1.原理介绍
三、动态规划案例:背包问题
1.原理介绍
四、贪心算法与动态规划的区别
五、总结
作者其他文章链接
正则表达式-CSDN博客
深入理解HashMap:Java中的键值对存储利器-CSDN博客

一、简介
贪心算法和动态规划是两种非常强大的算法设计策略,它们在许多复杂问题中都展现出了出色的性能。在计算机科学中,它们被广泛应用于解决优化问题,如资源分配、路径寻找等。在这篇博客中,我们将通过具体的Java案例来探讨这两种算法的设计和应用,并详细比较它们的区别。
二、贪心算法案例:活动选择问题
1.原理介绍
贪心算法是一种通过每一步的最优选择,希望得到全局最优解的算法。它通常基于当前状态和局部信息做出决策,而没有对问题进行全面的扫描和分解。贪心算法的关键在于在每一步选择中,都选取当前状态下最好或最优(即最有利)的选择,从而希望通过每个局部最优的选择,能够导致全局最优解。
活动选择问题是一种常见的贪心算法应用场景,它要求从一系列活动中选择出最大数量的活动,以便在给定时间内完成。贪心算法的策略是每次选择当前最优的活动,希望通过每个局部最优的选择,能够达到全局最优解
public class ActivitySelection { public static int selectActivities(int[] activityLengths, int[] activityStartTimes) { int n = activityLengths.length; int[] dp = new int[n]; int maxActivities = 0; for (int i = 0; i < n; i++) { int start = activityStartTimes[i]; int end = start + activityLengths[i]; for (int j = 0; j < i; j++) { if (activityStartTimes[j] <= start && end <= activityStartTimes[j] + activityLengths[j]) { dp[i] = 0; // conflict break; } else if (activityStartTimes[j] > start && end > activityStartTimes[j] && dp[j] == 1) { dp[i] = 0; // conflict break; } else if (activityStartTimes[j] <= start && end >= activityStartTimes[j] + activityLengths[j]) { dp[i] = 1; // OK } else { dp[i] = 0; // conflict } } if (dp[i] == 1) { maxActivities++; } } return maxActivities; }
}
三、动态规划案例:背包问题
1.原理介绍
动态规划是一种通过将问题分解为若干个子问题,并存储子问题的解,以便重复使用的方法。它特别适用于解决需要优化递归的问题,通过将问题分解为更小的部分,并利用这些子问题的解来构建最终的解决方案。动态规划的关键在于记忆化,它通过存储并重复使用之前子问题的解,从而避免重复计算,提高了算法的效率。
背包问题是动态规划的经典案例。我们有一个背包,有一定的承载重量,现在有一些物品,每个物品都有自己的重量和价值。我们希望在不超过背包承载重量的前提下,选择一些物品放入背包,使得背包中物品的总价值最大。我们可以将这个问题分解为几个子问题:对于给定的背包容量,我们能选择哪些物品?对于这些物品,我们应该选择哪些物品放入背包以获得最大的价值?
public class Knapsack { public static int knapSack(int W, int wt[], int val[], int n) { int i, w; int K[][] = new int[n+1][W+1]; for (i = 0; i <= n; i++) { for (w = 0; w <= W; w++) { if (i==0 || w==0) { K[i][w] = 0; } else if (wt[i-1] <= w) { K[i][w] = Math.max(val[i-1] + K[i-1][w-wt[i-1]], K[i-1][w]); } else { K[i][w] = K[i-1][w]; } } } return K[n][W]; }
}
四、贪心算法与动态规划的区别
- 问题分解方式:贪心算法通常试图找到局部最优解,希望通过每个局部最优的选择,能够达到全局最优解。它通常没有对问题进行全面扫描和分解,而是基于当前状态和局部信息做出决策。而动态规划则是将问题分解为若干个子问题,并存储子问题的解,以便重复使用。它通过将问题分解为更小的部分,并利用这些子问题的解来构建最终的解决方案。
- 记忆化:动态规划的一个重要特点是记忆化。它通过存储并重复使用之前子问题的解,从而避免重复计算,提高了算法的效率。而贪心算法则通常没有这种记忆功能,它只关注当前状态和局部最优解。
- 全局优化:贪心算法通常只能保证局部最优,而无法保证全局最优。这是因为贪心算法在每一步都选择当前最优的选项,而不考虑这可能对全局产生的影响。而动态规划则通过解决子问题并整合答案,更有可能找到全局最优解。
- 适用场景:贪心算法在某些特定类型的问题上表现出色,例如活动选择、硬币找零等问题。而动态规划则更适用于解决复杂优化问题,如背包问题、旅行商问题等。
- 时间复杂度:在某些情况下,动态规划的时间复杂度可能高于贪心算法。这是因为动态规划需要解决和存储大量的子问题,而贪心算法则只需要考虑当前状态和局部信息。然而,对于一些特定问题,动态规划可能会提供更优的解决方案。
五、总结
贪心算法和动态规划是两种非常强大的算法设计策略,它们在许多复杂问题中都展现出了出色的性能。通过以上两个Java案例,我们可以看到它们在解决实际问题中的效果和优势。在选择使用贪心算法还是动态规划时,我们需要根据问题的性质、全局优化要求、计算资源等因素进行综合考虑。同时,深入理解这两种算法的工作原理和适用场景,将有助于我们在解决问题时选择合适的算法设计策略。
相关文章:
贪心算法和动态规划
目录 一、简介 二、贪心算法案例:活动选择问题 1.原理介绍 三、动态规划案例:背包问题 1.原理介绍 四、贪心算法与动态规划的区别 五、总结 作者其他文章链接 正则表达式-CSDN博客 深入理解HashMap:Java中的键值对存储利器-CSDN博客…...
jsp 设备预约管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
一、源码特点 JSP 设备预约管理系统是一套完善的java web信息管理系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0…...
Python:核心知识点整理大全10-笔记
目录 5.4 使用 if 语句处理列表 5.4.1 检查特殊元素 toppings.py 5.4.2 确定列表不是空的 5.4.3 使用多个列表 5.5 设置 if 语句的格式 5.6 小结 第6章 字 典 6.1 一个简单的字典 alien.py 6.2 使用字典 6.2.1 访问字典中的值 6.2.2 添加键—值对 6.2.3 先创建一…...
Hive数据库系列--Hive数据类型/Hive字段类型/Hive类型转换
文章目录 一、Hive数据类型1.1、数值类型1.2、字符类型1.3、日期时间类型1.4、其他类型1.5、集合数据类型1.5.1、Struct举例1.5.2、Array举例1.5.3、Map举例 二、数据类型转换2.1、隐式转换2.2、显示转换 三、字段类型的使用3.1、DECIMAL(precision,scale) 本章主要…...
在Spring Cloud中使用组件Ribbon和Feign,并分别创建子模块注册到Eureka中去
ok,在上篇文章中我们讲了在Spring cloud中使用Zuul网关,这篇文章我们将Spring Cloud的五大核心组件的Ribbon和Feign分别创建一个微服务模块。 题外话,本篇博客就是配置子模块,或者说是微服务,然后将微服务正式启动之前…...
(JAVA)-缓冲流
缓冲流能高效的读取数据 缓冲流底层自带了8192的缓冲区提高性能,他在原有的流上进行了包装,加上了缓冲效果 原理: 读入时首先会将内存中缓冲区大小的数据读入缓冲区中,接着下次读取直接从缓冲区中读取数据,当缓冲区…...
Autosar UDS-CAN诊断开发02-1(CAN诊断帧格式类型详解、CANFD诊断帧格式类型详解、15765-2(CANTP层)的意义)
目录 前言 CANTP层(15765-2协议)存在的意义 CANTP层(15765-2协议)帧类型详细解读(普通CAN格式) 四种诊断报文类型 单帧SingleFrame(SF) 首帧:FirstFrame(FF) 流控帧:FlowCont…...
swing快速入门(三)
解答一下上一篇关于留下的关于布局管理器的疑问 上一篇 几种常见的布局管理器 看不懂?看不懂没关系,这篇是概念篇,大概了解一下就行~ 1.FlowLayout(流式布局):按照从左到右、从上到下的顺序依次排列组件。…...
Swagger PHP Thinkphp 接口文档
安装 1. 安装依赖 composer require zircote/swagger-php 2. 下载Swagger UI git clone https://github.com/swagger-api/swagger-ui.git 3. 复制下载好的Swagger UI 中的dist目录到public目录中,修改目录名称 cp -rf swagger-ui/dist /home/htdocs/public/ m…...
12.9每日一题(备战蓝桥杯循环结构)
12.9每日一题(备战蓝桥杯循环结构) 题目 2165: 求平均年龄题目描述输入输出样例输入样例输出来源/分类 题解 2165: 求平均年龄题目 2166: 均值题目描述输入输出样例输入样例输出来源/分类 题解 2166: 均值题目 2167: 求整数的和与均值题目描述输入输出样…...
与时代共进退
还记得当初自己为什么选择计算机? 当初你问我为什么选择计算机,我笑着回答:“因为我梦想成为神奇的码农!我想像编织魔法一样编写程序,创造出炫酷的虚拟世界!”谁知道,我刚入门的那天࿰…...
Python 云服务器应用,Https,定时重启
Python 云服务器应用,Https,定时重启 环境搭建Python模块模块导入生成Flask实例GET处理启动服务器打开网页验证 GET接入证书 支持https申请证书下载证书保留 xxx.crt 和 xxx.key文件就可以了 copy到python项目目录ssl_context 配置 宝塔面板操作在www目录下新建python工作目录在…...
pytorch 笔记:dist 和 cdist
1 dist 1.1 基本使用方法 torch.dist(input, other, p2) 计算两个Tensor之间的p-范数 1.2 主要参数 input输入张量other另一个输入张量p范数 input 和 other的形状需要是可广播的 1.3 举例 import torchxtorch.randn(4) x #tensor([ 1.2698, -0.1209, 0.0462, -1.3271…...
Java的List中的各种浅拷贝和深拷贝问题
先来看一组代码 public class Temp{public static void main(String[] args) {List<Integer> list new ArrayList<>();list.add(1);list.add(2);list.add(3);List<Integer> temp list;list.add(4);System.out.println(list.toString());System.out.print…...
20231207_最新已测_Centos7.4安装nginx1.24.0_安装详细步骤---Linux工作笔记066
以前安装的太模糊了,干脆重新写一个: 1.首先下载对应的nginx-1.24.0.tar.gz安装文件 2.然后: 去执行命令 安装依赖 yum install -y gcc yum install -y pcre pcre-devel yum install -y zlib zlib-devel yum install -y openssl openssl-devel 3.然后:去解压 tar -zxvf ngi…...
前端知识笔记(二十六)———React如何像Vue一样将css和js写在同一文件
如果想在React中想要像Vue一样把css和js写到一个文件中,可以使用CSS-in-JS。 使用CSS-in-JS 下载 npm i styled-components使用 就像写scss一样,不过需要声明元素的类型 基本语法及展示如下 import styled from "styled-components"expor…...
Photoshop Circular Text
Ctrl N 新增 现学现卖...
深入解析Spring Boot中的注解@PathVariable、@RequestParam、@RequestBody的正确使用
文章目录 1. 引言2. PathVariable:处理路径变量2.1 简介2.2 使用示例 3. RequestParam:处理请求参数3.1 简介3.2 使用示例 4. RequestBody:处理请求体4.1 简介4.2 使用示例 5. 多个注解的组合使用6. 参数绑定的原理6.1 HandlerMethodArgument…...
Qt Location中加载地图对象
在Qt Location中加载地图对象,你可以按照以下步骤进行操作: 1,首先,确保你已经安装了Qt Location模块,并在项目中包含了相应的头文件。在项目文件(.pro)中添加以下行: QT locatio…...
4-Docker命令之docker ps
1.docker ps介绍 docker ps命令是用来列出容器的相关信息 2.docker ps用法 docker ps [参数] [rootcentos79 ~]# docker ps --helpUsage: docker ps [OPTIONS]List containersAliases:docker container ls, docker container list, docker container ps, docker psOptions…...
Vim 调用外部命令学习笔记
Vim 外部命令集成完全指南 文章目录 Vim 外部命令集成完全指南核心概念理解命令语法解析语法对比 常用外部命令详解文本排序与去重文本筛选与搜索高级 grep 搜索技巧文本替换与编辑字符处理高级文本处理编程语言处理其他实用命令 范围操作示例指定行范围处理复合命令示例 实用技…...
ubuntu搭建nfs服务centos挂载访问
在Ubuntu上设置NFS服务器 在Ubuntu上,你可以使用apt包管理器来安装NFS服务器。打开终端并运行: sudo apt update sudo apt install nfs-kernel-server创建共享目录 创建一个目录用于共享,例如/shared: sudo mkdir /shared sud…...
云启出海,智联未来|阿里云网络「企业出海」系列客户沙龙上海站圆满落地
借阿里云中企出海大会的东风,以**「云启出海,智联未来|打造安全可靠的出海云网络引擎」为主题的阿里云企业出海客户沙龙云网络&安全专场于5.28日下午在上海顺利举办,现场吸引了来自携程、小红书、米哈游、哔哩哔哩、波克城市、…...
Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...
【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力
引言: 在人工智能快速发展的浪潮中,快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型(LLM)。该模型代表着该领域的重大突破,通过独特方式融合思考与非思考…...
macOS多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用
文章目录 问题现象问题原因解决办法 问题现象 macOS启动台(Launchpad)多出来了:Google云端硬盘、YouTube、表格、幻灯片、Gmail、Google文档等应用。 问题原因 很明显,都是Google家的办公全家桶。这些应用并不是通过独立安装的…...
ardupilot 开发环境eclipse 中import 缺少C++
目录 文章目录 目录摘要1.修复过程摘要 本节主要解决ardupilot 开发环境eclipse 中import 缺少C++,无法导入ardupilot代码,会引起查看不方便的问题。如下图所示 1.修复过程 0.安装ubuntu 软件中自带的eclipse 1.打开eclipse—Help—install new software 2.在 Work with中…...
python执行测试用例,allure报乱码且未成功生成报告
allure执行测试用例时显示乱码:‘allure’ �����ڲ����ⲿ���Ҳ���ǿ�&am…...
Web 架构之 CDN 加速原理与落地实践
文章目录 一、思维导图二、正文内容(一)CDN 基础概念1. 定义2. 组成部分 (二)CDN 加速原理1. 请求路由2. 内容缓存3. 内容更新 (三)CDN 落地实践1. 选择 CDN 服务商2. 配置 CDN3. 集成到 Web 架构 …...
