【代码+详解】算法题 : 金银岛

2024-06-10 17:36
文章标签 算法 代码 详解 金银岛

本文主要是介绍【代码+详解】算法题 : 金银岛,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

❗❗❗必看:
下列题我全部都使用 Java 语言写的,并且均可以提交成功,获得Accepted 结果的. 如果代码和详解看了之后,对答案有任何疑问,都可以在评论区提出来,我都会一个一个回答.

❗❗❗感谢大家的支持,如果喜欢我的博客,关注 点赞 收藏 评论一波,非常感谢!!!

文章目录

  • 题目:金银岛
    • 样例测试
    • 代码
    • 图示
    • 金银岛算法题解
      • 初步思路
      • 具体步骤
      • 总结方法

题目:金银岛

某天KID利用飞行器飞到了一个金银岛上,上面有许多珍贵的金属,KID虽然更喜欢各种宝石的艺术品,可是也不拒绝这样珍贵的金属。但是他只带着一个口袋,口袋至多只能装重量为w的物品。岛上金属有s个种类, 每种金属重量不同,分别为n(1), n(2), … , n(s),同时每个种类的金属总的价值也不同,分别为v(1),v(2), …, v(s)。KID想一次带走价值尽可能多的金属,问他最多能带走价值多少的金属。注意到金属是可以被任意分割的,并且金属的价值和其重量成正比。

Input

第1行是测试数据的组数k,后面跟着k组输入。

每组测试数据占3行,第1行是一个正整数w (1 <= w <= 10000),表示口袋承重上限。第2行是一个正整数s (1 <= s <=100),表示金属种类。第3行有2s个正整数,分别为n(1), v(1), n(2), v(2), … , n(s), v(s)分别为第一种,第二种,…,第s种金属的总重量和总价值(1 <= n(i) <= 10000, 1 <= v(i) <= 10000)。

Output

k行,每行输出对应一个输入。输出应精确到小数点后2位。

样例测试

输入

2
50
4
10 100 50 30 7 34 87 100
10000
5
1 43 43 323 35 45 43 54 87 43

输出

171.93
508.00

代码

import java.util.*;public class Main {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int k = sc.nextInt(); // 读取测试数据的组数List<int[]> testCases = new ArrayList<>();for (int i = 0; i < k; i++) {int w = sc.nextInt(); // 读取口袋承重上限int s = sc.nextInt(); // 读取金属种类int[] metals = new int[2 * s + 2];metals[0] = w;metals[1] = s;for (int j = 2; j < 2 * s + 2; j++) {metals[j] = sc.nextInt(); // 读取每种金属的重量和价值}testCases.add(metals);}List<String> results = maxMetalValue(k, testCases);for (String result : results) {System.out.println(result); // 输出结果}sc.close();}public static List<String> maxMetalValue(int k, List<int[]> testCases) {List<String> results = new ArrayList<>();for (int i = 0; i < k; i++) {int w = testCases.get(i)[0];int s = testCases.get(i)[1];int[] metals = Arrays.copyOfRange(testCases.get(i), 2, testCases.get(i).length);List<Metal> metalList = new ArrayList<>();for (int j = 0; j < s; j++) {int weight = metals[2 * j];int value = metals[2 * j + 1];metalList.add(new Metal(weight, value));}metalList.sort((m1, m2) -> Double.compare(m2.unitValue, m1.unitValue));double totalValue = 0.0;for (Metal metal : metalList) {if (w <= 0) break;if (metal.weight <= w) {totalValue += metal.value;w -= metal.weight;} else {totalValue += metal.unitValue * w;w = 0;}}results.add(String.format("%.2f", totalValue)); // 这里进行格式化并添加到结果中}return results;}static class Metal {double unitValue;int weight;int value;public Metal(int weight, int value) {this.weight = weight;this.value = value;this.unitValue = (double) value / weight;}}
}

图示

画的有点抽象,但是非常建议把下面的图示结合代码一起看,学起来的效率非常高.保证一看就会

在这里插入图片描述

金银岛算法题解

初步思路

这个问题是典型的“贪心算法”应用。通过计算每种金属的单位价值(即每单位重量的价值),然后优先选择单位价值最高的金属直到达到口袋承重上限,可以最大化KID能带走的金属总价值。

具体步骤

  1. 读取输入数据:从输入中读取测试数据的组数k,之后对每组测试数据分别处理。
  2. 数据解析:对每组测试数据,先读取口袋承重上限w,然后读取金属种类数s,接着读取每种金属的重量和价值。
  3. 计算单位价值:为每种金属计算单位价值(即每单位重量的价值 = 总价值 / 总重量)。
  4. 按单位价值排序:将金属按单位价值从高到低排序。
  5. 贪心选择:从单位价值最高的金属开始,尽量多地选择直到达到承重上限。如果当前金属重量超过剩余承重上限,则选择部分金属使其正好达到承重上限。
  6. 记录结果:记录每组测试数据的最大金属总价值,并格式化到小数点后两位。

总结方法

这种方法的关键在于贪心选择的策略,通过单位价值的排序和逐步选择,确保每一步都尽可能提高总价值。这样的策略在面对能够部分选择的物品问题时非常有效。通过这一题,我们可以更好地理解贪心算法在解决部分选择问题中的应用,并学习如何通过排序和逐步选择来达到最优解。

这篇关于【代码+详解】算法题 : 金银岛的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1048823

相关文章

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Java中的stream流分组示例详解

《Java中的stream流分组示例详解》Java8StreamAPI以函数式风格处理集合数据,支持分组、统计等操作,可按单/多字段分组,使用String、Map.Entry或Java16record... 目录什么是stream流1、根据某个字段分组2、按多个字段分组(组合分组)1、方法一:使用 Stri

使用Spring Cache本地缓存示例代码

《使用SpringCache本地缓存示例代码》缓存是提高应用程序性能的重要手段,通过将频繁访问的数据存储在内存中,可以减少数据库访问次数,从而加速数据读取,:本文主要介绍使用SpringCac... 目录一、Spring Cache简介核心特点:二、基础配置1. 添加依赖2. 启用缓存3. 缓存配置方案方案

Spring创建Bean的八种主要方式详解

《Spring创建Bean的八种主要方式详解》Spring(尤其是SpringBoot)提供了多种方式来让容器创建和管理Bean,@Component、@Configuration+@Bean、@En... 目录引言一、Spring 创建 Bean 的 8 种主要方式1. @Component 及其衍生注解

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

从基础到进阶详解Python条件判断的实用指南

《从基础到进阶详解Python条件判断的实用指南》本文将通过15个实战案例,带你大家掌握条件判断的核心技巧,并从基础语法到高级应用一网打尽,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录​引言:条件判断为何如此重要一、基础语法:三行代码构建决策系统二、多条件分支:elif的魔法三、

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum