贪心算法实现

1、概述

        贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而

希望导致结果是最好或最优的算法。

        贪心算法的每一步都是基于当前状态下的最优解来选择下一步,因此它不能保证全局最优

解,只能保证局部最优解。

        贪心算法的优点是思路简单、易于实现、时间复杂度较低,但缺点是可能得到非全局最优解。

2、应用场景

  1. 背包问题:给定一组物品,每种物品都有自己的重量和价值,确定一个总重量不超过背包容量的情况下,使得背包中的总价值最大。
  2. 最小生成树:给定一个带权重的无向图,求出该图的最小生成树。
  3. 旅行商问题:给定一组城市和每对城市之间的距离,求出访问每个城市一次并返回到原点的最短路径。
  4. 最大匹配问题:给定一个字符串和一个模式串,求出模式串在字符串中出现的最大匹配长度。
  5. 0/1背包问题:给定一组物品,每种物品都有自己的重量和价值,确定一个总重量不超过背包容量的情况下,使得背包中的总价值最大。
  6. 找零问题:找到最少数量的硬币,使它们的总和等于给定的金额。

3、解决背包问题

解决思路

贪心策略:在每一步选择当前可用物品中单位价值最高的物品放入背包,直到背包容量达到上限。

算法步骤:

  1. 初始化:将物品按照单位价值从大到小排序。
  2. 遍历排序后的物品列表:
    • 如果当前物品的重量小于等于背包容量,将该物品放入背包,并更新背包的总重量和总价值。
    • 如果当前物品的重量大于背包容量,跳过该物品。
  3. 返回最终放入背包的物品和它们的总价值。

元素

  • 物品
    • 重量
    • 价值
  • 背包
    • 容量:可以承受的重量。

选择装入背包的物品价值最大。

代码

package com.ybw.algorithm.greedy.dto;import lombok.AllArgsConstructor;
import lombok.Data;/*** @author weixiansheng* @version V1.0* @className Goods* @date 2023/12/22**/
@Data
@AllArgsConstructor
public class Goods {/*** 商品价格** @author: weixiansheng* @date: 2023/12/22**/private Integer price;/*** 重量** @author: weixiansheng* @date: 2023/12/22**/private Integer weight;
}
package com.ybw.algorithm.greedy;import com.ybw.algorithm.greedy.dto.Goods;
import org.junit.jupiter.api.Test;import java.util.ArrayList;
import java.util.List;/*** 贪心算法-背包问题** @author weixiansheng* @version V1.0* @className KnapsackProblemTest* @date 2023/12/25**/
public class KnapsackProblemTest {/*** @methodName: knapsackProblemTest* @return: void* @author: weixiansheng* @date: 2023/12/22**/@Testpublic void knapsackProblemTest() {//1、定义物品列表List<Goods> goodsList = new ArrayList<>();goodsList.add(new Goods(60, 10));goodsList.add(new Goods(100, 20));goodsList.add(new Goods(120, 30));// 背包的容量int capacity = 50;// 输出背包的最大价值System.out.println(maxValue(capacity, goodsList));}private int maxValue(int capacity, List<Goods> goodsList) {int totalValue = 0;for (Goods goods : goodsList) {if (capacity >= goods.getWeight()) {totalValue += goods.getPrice();capacity -= goods.getWeight();} else {totalValue += goods.getPrice() * (capacity / goods.getWeight());break;}}return totalValue;}
}

运行结果:160。全局最优解为220。

总结:它不能保证全局最优解,只能保证局部最优解。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

小区物业大数据监控服务平台(PSD文件资料)

现分享简约物业大数据平台页面、小区物业大数据监控服务平台模版的UI源文件&#xff0c;供设计师们快速获取PS源文件完成工作。 若需 更多行业 相关的大屏&#xff0c;请移步小7的另一篇文章&#xff1a;200套精选数据可视化大屏&#xff0c;大屏PSD设计&#xff08;各行业大屏…

ACE中为socket增加keepalive策略(windows和linux)

0、现象描述 在国产麒麟系统下,基于ACE的tcp-socket,如果长时间不操作,则会自动切断连接,经测试发现,这个时间的上限为30分钟(几乎不差1秒) 经查看/proc/sys/net/ipv4/tcp_keepalive_time=7200,按说是2小时,但测试发现就是30分钟。索性,就通过程序来动态设置keepaliv…

PHP-FPM 的主要作用和功能:

管理 PHP 进程池&#xff1a; PHP-FPM 负责启动和管理 PHP 进程池。进程池是一组 PHP 进程&#xff0c;它们等待来自 Web 服务器的请求。PHP-FPM 可以根据配置中的参数来动态调整进程池的大小&#xff0c;以适应不同的负载情况。 处理 FastCGI 请求&#xff1a; PHP-FPM 使用 F…

ssh工具 向指定的ssh服务器配置公钥

此文分享一个python脚本,用于向指定的ssh服务器配置公钥,以达到免密登录ssh服务器的目的。 效果演示 🔥完整演示效果 👇第一步,显然,我们需要选择功能 👇第二步,确认 or 选择ssh服务器 👇第三步,输入ssh登录密码,以完成公钥配置 👇验证,我们通过ssh登录…

python区块链简单模拟【03】

引入钱包&#xff0c;账户地址&#xff0c;公私钥 # 导入椭圆曲线算法 from ecdsa import SigningKey, SECP256k1, VerifyingKey, BadSignatureError import binascii import base64 from hashlib import sha256class Wallet:"""钱包"""def __i…

(1)(1.11) SiK Radio v2(一)

文章目录 前言 1 概述 2 特点 3 状态LED灯 前言 SiK 遥测无线电是在自动驾驶仪和地面站之间建立遥测连接的最简单方法之一。本文提供了如何连接和配置无线电的基本用户指南。 3DR Radio v2&#xff08;SiKRadio 的消费者版本&#xff09; &#xff01;Note 本页面以前的…

企业跨境数据传输的创新技术和应用领域

在当前数字化时代&#xff0c;跨境数据传输成为一个极为关键的领域。随着数据传输需求的不断增加&#xff0c;跨国企业在这一过程中面临着越来越多的问题。为了解决这些挑战&#xff0c;创新技术层出不穷&#xff0c;为跨境数据传输提供了更高效、安全和可靠的解决方案。本文将…

visual studio code B站教程:GPT4

B站教程&#xff1a;AI编程辅助神器-CodeMoss使用介绍_哔哩哔哩_bilibili 通用 General 按 Press 功能 Function Ctrl Shift P&#xff0c;F1 显示命令面板 Show Command Palette Ctrl P 快速打开 Quick Open Ctrl Shift N 新窗口/实例 New window/instance Ctrl Sh…

经验 | IDEA常用快捷键

1、编辑&#xff08;Editing&#xff09; Ctrl Space 基本的代码完成&#xff08;类、方法、属性&#xff09; Ctrl Alt Space 快速导入任意类 Ctrl Shift Enter 语句完成 Ctrl P 参数信息&#xff08;在方法中调用参数&#xff09; Ctrl Q 快速查看文档 Shift F…

Flink CDC 1.0至3.0回忆录

Flink CDC 1.0至3.0回忆录 一、引言二、CDC概述三、Flink CDC 1.0&#xff1a;扬帆起航3.1 架构设计3.2 版本痛点 四、Flink CDC 2.0&#xff1a;成长突破4.1 DBlog 无锁算法4.2 FLIP-27 架构实现4.3 整体流程 五、Flink CDC 3.0&#xff1a;应运而生六、Flink CDC 的影响和价值…

腾讯云4核8G服务器选择轻量还是标准型S5服务器?

腾讯云4核8G服务器优惠价格表&#xff0c;云服务器CVM标准型S5实例4核8G配置价格15个月1437.3元&#xff0c;5年6490.44元&#xff0c;轻量应用服务器4核8G12M带宽一年446元、529元15个月&#xff0c;阿腾云atengyun.com分享腾讯云4核8G服务器详细配置、优惠价格及限制条件&…

whistle网络监控 fiddler的开源替代

github源码&#xff1a;https://github.com/avwo/whistle 官网说明&#xff1a;http://wproxy.org/whistle/ windows/mac一键安装 先安装nodejs 然后运行命令 npm i -g whistle && w2 start --init启动 w2 start停止 w2 stop注意停止后要手动关闭代理服务器设置 w…

【免杀测试】Kali之Metasploit几款工具免杀练习

余磊 不知攻&#xff0c;焉知防。作为渗透测试攻城狮&#xff0c;实战之前要做大量的攻防练习。一般黑客拿到主机的shell之后&#xff0c;需要留后门方便进行下一步的渗透。普通的木马已经很容易被查杀工具识别&#xff0c;这时就催生出了免杀技术来绕过杀毒软件。 下面就尝试…

为什么需要升级EKS

当谈到在云环境中管理容器化应用程序时&#xff0c;Amazon EKS&#xff08;Elastic Kubernetes Service&#xff09;是一个备受欢迎的选择。它为用户提供了一个强大且高度可扩展的平台&#xff0c;使他们能够轻松地在Kubernetes上运行和管理应用程序。随着技术的不断发展&#…

[hive] sql中distinct的用法和注意事项

在 Hive SQL 中&#xff0c;DISTINCT 用于去重查询结果中的行。它返回唯一的行&#xff0c;消除结果集中的重复项。以下是 DISTINCT 的基本用法和一些注意事项&#xff1a; 基本用法&#xff1a; -- 获取列1和列2的唯一组合 SELECT DISTINCT column1, column2 FROM your_tabl…

前端性能优化十五:js优化的总体原则

1. js优化的总体原则: ①. 当需要时才优化:a. 项目到了某个阶段才需要优化.(1). 大的改版、代码架构无法满足现有业务.②. 考虑可维护性:a. 考虑团队的开发水平、规范.b. 不是为了优化牺牲了后续的可维护性.(1). 提升JS文件的加载性能: ①. 加载元素的顺序:a. css文件放在<…

Domino 14中的重新设定样式功能

大家好&#xff0c;才是真的好。 上周末&#xff0c;我测试了一些Domino 14版本新功能&#xff0c;令人惊喜的是重新设定样式&#xff08;Restyle&#xff09;新特性。 如果不知道什么是Restyle&#xff0c;请参考这篇《Notes 12.0.2版本新特性》。 简而言之&#xff0c;Res…

十大VSCODE 插件推荐2023

1、海鲸AI 插件链接&#xff1a;ChatGPT GPT-4 - 海鲸AI - Visual Studio Marketplace 包含了ChatGPT(3.5/4.0)等多个AI模型。可以实现代码优化&#xff0c;代码解读&#xff0c;代码bug修复等功能&#xff0c;反应迅捷&#xff0c;体验出色&#xff0c;是一个多功能的AI插件…

java简介

1. 介绍 Java是一种广泛使用的面向对象编程语言&#xff0c;由Sun Microsystems开发&#xff0c;现在归Oracle公司管理。它以其跨平台性、安全性和可靠性而闻名&#xff0c;并被用于各种应用程序开发领域。本博客将介绍Java的基本概念、特性和用法。 2. Java的特性 a) 简单性 J…