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

每日c/c++题 备战蓝桥杯(P2240 【深基12.例1】部分背包问题)

P2240 【深基12.例1】部分背包问题 - 详解与代码实现

一、题目概述

阿里巴巴要在承重为 T 的背包中装走尽可能多价值的金币,共有 N 堆金币,每堆金币有总重量和总价值。金币可分割,且分割后单位价格不变。目标是求出能装走的最大价值。

二、问题分析

这个问题是典型的贪心算法应用场景——部分背包问题。核心在于如何选择金币堆的装入顺序,以实现价值最大化。

关键点:

  1. 贪心策略:优先装单位价值(价值 / 重量)高的金币堆,这样在有限的背包容量下,能获得最大价值。
  2. 可分割性:金币可分割,意味着可以部分装入某堆金币,这使得问题可以用贪心策略解决,而无需动态规划(如 0-1 背包问题)。

三、解题思路

步骤详解:

  1. 计算单位价值:对每堆金币,计算其单位价值(价值 / 重量)。
  2. 排序:将金币堆按单位价值从高到低排序,这样可以优先选择价值密度高的金币。
  3. 装背包过程
    • 遍历排序后的金币堆。
    • 若背包剩余容量足够装下整堆金币,则全部装入,并累加对应价值。
    • 若背包剩余容量不足,则装入剩余容量所能容纳的部分金币,价值按比例累加。
    • 直到背包装满或所有金币堆处理完毕。

四、代码实现

#include<bits/stdc++.h>
using namespace std;
struct node
{int num; // 记录金币堆的索引(可省略)double v; // 单位价值
}d[105];
bool cmp(node x, node y)
{if (x.v > y.v) return true;return false;
}
int main()
{int N, T;int m[105] = { 0 }; // 每堆金币的重量int v[105] = { 0 }; // 每堆金币的价值cin >> N >> T;for (int i = 0; i < N; ++i){cin >> m[i] >> v[i];d[i].v = (double) v[i] / (double) m[i]; // 计算单位价值d[i].num = i; // 记录索引(实际未用)}sort(d, d + N, cmp); // 按单位价值从高到低排序double sum = 0;int wei = 0; // 已装重量for (int i = 0; i < N; i++){if(T - wei > 0) // 背包未满{if (wei + m[d[i].num] > T) // 当前堆无法完全装入{sum += (T - wei) * d[i].v; // 装入部分wei = T; // 背包满了}else{sum += d[i].v * m[d[i].num]; // 装入整堆}wei += m[d[i].num]; // 更新已装重量(即使装满 T 后也不影响)}}printf("%.2lf", sum); // 输出保留两位小数return 0;
}

五、代码分析

数据结构:

  • 使用结构体 node 存储每堆金币的单位价值和索引(索引也可省略)。
  • 数组 mv 分别存储金币堆的重量和价值。

算法流程:

  1. 输入读取和预处理:读取金币堆数量 N 和背包承重 T,计算每堆金币的单位价值。
  2. 排序:通过自定义比较函数 cmp,将金币堆按单位价值从高到低排序。
  3. 贪心装背包
    • 遍历排序后的金币堆,根据背包剩余容量决定装入整堆还是部分。
    • 累加价值到总价值变量 sum 中。
  4. 输出结果:使用 printf 输出总价值,保留两位小数。

六、测试用例与结果验证

输入示例:

4 50
10 60
20 100
30 120
15 45

输出:

240.00

验证过程:

  1. 各堆金币的单位价值分别为:
    • 堆 0:60 / 10 = 6.0
    • 堆 1:100 / 20 = 5.0
    • 堆 2:120 / 30 = 4.0
    • 堆 3:45 / 15 = 3.0
  2. 排序后顺序为堆 0 → 堆 1 → 堆 2 → 堆 3。
  3. 背包容量 T=50:
    • 先装堆 0,重 10,价值 60,剩余容量 40。
    • 装堆 1,重 20,价值 100,剩余容量 20。
    • 装堆 2,重 30,但剩余容量只有 20,装入 20 重量,价值 4 * 20 = 80(单位价值是 4)。
    • 总价值:60 + 100 + 80 = 240.00。

七、总结与拓展

总结:

部分背包问题通过贪心策略(按单位价值排序)可以高效求解。关键在于理解贪心选择的正确性:优先装单位价值高的物品,能保证全局价值最大。

拓展:

  1. 0-1 背包问题:物品不可分割,需用动态规划解决。
  2. 多约束背包问题:如同时有重量和体积限制,需更复杂的算法。
  3. 变种问题:如要求必须装满背包,或物品有依赖关系等。

希望本篇文章能帮助你更好地理解部分背包问题的解法。如果有其他问题或需要进一步探讨,欢迎留言交流!

相关文章:

每日c/c++题 备战蓝桥杯(P2240 【深基12.例1】部分背包问题)

P2240 【深基12.例1】部分背包问题 - 详解与代码实现 一、题目概述 阿里巴巴要在承重为 T 的背包中装走尽可能多价值的金币&#xff0c;共有 N 堆金币&#xff0c;每堆金币有总重量和总价值。金币可分割&#xff0c;且分割后单位价格不变。目标是求出能装走的最大价值。 二、…...

Java异步编程:CompletionStage接口详解

CompletionStage 接口分析 接口能力概述 CompletionStage 是 Java 8 引入的接口&#xff0c;用于表示异步计算的一个阶段&#xff0c;它提供了强大的异步编程能力&#xff1a; ​​链式异步操作​​&#xff1a;允许将一个异步操作的结果传递给下一个操作​​组合操作​​&a…...

Java后端接受前端数据的几种方法

在前后端分离的开发模式中&#xff0c;前端&#xff08;Vue&#xff09;与后端&#xff08;Java&#xff09;的数据交互有多种格式&#xff0c;下面详细介绍几种常见的格式以及后端对应的接收方式。 一、JSON 格式 前端传输 在 Vue 里&#xff0c;可借助 axios 把数据以 JSO…...

Oracle OCP认证的技术定位怎么样?

一、引言&#xff1a;Oracle OCP认证的技术定位​ Oracle Certified Professional&#xff08;OCP&#xff09;认证是数据库领域含金量最高的国际认证之一&#xff0c;其核心价值在于培养具备企业级数据库全生命周期管理能力的专业人才。随着数字化转型加速&#xff0c;OCP认证…...

powershell7.5@.net环境@pwsh7.5在部分windows10系统下的运行问题

文章目录 powershell7.5及更高版本和.net 9解决方案 powershell7.5及更高版本和.net 9 相对较新的.Net 9版本在老一些的windows10系统上(比如内核版本号:10.0.19044.1288以及之前的),由于默认启用了CET,导致编译运行失败,需要自己在项目中添加关闭CET的配置语句才能够顺利编译…...

基于微信小程序的垃圾分类系统

博主介绍&#xff1a;java高级开发&#xff0c;从事互联网行业六年&#xff0c;熟悉各种主流语言&#xff0c;精通java、python、php、爬虫、web开发&#xff0c;已经做了六年的毕业设计程序开发&#xff0c;开发过上千套毕业设计程序&#xff0c;没有什么华丽的语言&#xff0…...

CSS3 渐变、阴影和遮罩的使用

全文目录&#xff1a; 开篇语**前言****1. CSS3 渐变 (Gradient)****1.1 线性渐变 (linear-gradient)****1.2 径向渐变 (radial-gradient)** **2. CSS3 阴影 (Shadow)****2.1 盒子阴影 (box-shadow)****2.2 文本阴影 (text-shadow)** **3. CSS3 遮罩 (Mask)****3.1 基本遮罩 (m…...

Spring Boot 全局配置文件优先级

好的&#xff0c;Spring Boot的全局配置文件优先级是一个非常重要的概念&#xff0c;它决定了在不同位置的同名配置属性以哪个为准。 Spring Boot 全局配置文件优先级核心知识点 &#x1f4cc; 文件格式优先级: 在同一目录下&#xff0c;如果同时存在 application.properties 和…...

流媒体基础解析:视频清晰度的关键因素

在视频处理的过程中&#xff0c;编码解码及码率是影响视频清晰度的关键因素。今天&#xff0c;我们将深入探讨这些概念&#xff0c;并解析它们如何共同作用于视频质量。 编码解码概述 编码&#xff0c;简单来说&#xff0c;就是压缩。视频编码的目的是将原始视频数据压缩成较…...

grid网格布局

使用flex布局的痛点 如果使用justify-content: space-between;让子元素两端对齐&#xff0c;自动分配中间间距&#xff0c;假设一行4个&#xff0c;如果每一行都是4的倍数那没任何问题&#xff0c;但如果最后一行是2、3个的时候就会出现下面的状况&#xff1a; /* flex布局 两…...

C#数字金额转中文大写金额:代码解析

C#数字金额转中文大写金额&#xff1a;代码解析 在金融相关的业务场景中&#xff0c;我们常常需要将数字金额转换为中文大写金额&#xff0c;以避免金额被篡改&#xff0c;增加金额的准确性和安全性。本文将深入解析一段 C# 代码&#xff0c;这段代码通过巧妙的设计&#xff0…...

Vehicle HAL(2)--Vehicle HAL 的启动

目录 1. VehicleService-main 函数分析 2. 构建EmulatedVehicleHal 2.1 EmulatedVehicleHal::EmulatedVehicleHal(xxx) 2.2 EmulatedVehicleHal::initStaticConfig() 2.3 EmulatedVehicleHal::onPropertyValue() 3. 构建VehicleEmulator 4. 构建VehicleHalManager (1)初…...

JS中的函数防抖和节流:提升性能的关键技术

在JavaScript开发中&#xff0c;函数防抖和节流是两种常用的优化技术&#xff0c;用于处理那些可能会被频繁触发的事件&#xff0c;如resize、scroll、mousemove等。本文将详细介绍函数防抖和节流的概念、实现方法以及它们之间的区别。 一、什么是函数防抖和节流&#xff1f; …...

Android Compose开发架构选择指南:单Activity vs 多Activity

简介 掌握Jetpack Compose的Activity架构选择,是构建高性能、易维护Android应用的关键一步。在2025年的Android开发领域,随着Jetpack Compose的成熟和Android系统对多窗口模式的支持,开发者面临架构选择时需要更加全面地考虑各种因素。本文将深入探讨单Activity架构和多Act…...

【Netty系列】Reactor 模式 1

目录 一、Reactor 模式的核心思想 二、Netty 中的 Reactor 模式实现 1. 服务端代码示例 2. 处理请求的 Handler 三、运行流程解析&#xff08;结合 Reactor 模式&#xff09; 四、关键点说明 五、与传统模型的对比 六、总结 Reactor 模式是 Netty 高性能的核心设计思想…...

vue3 el-input type=“textarea“ 字体样式 及高度设置

在Vue 3中&#xff0c;如果你使用的是Element Plus库中的<el-input>组件作为文本域&#xff08;type"textarea"&#xff09;&#xff0c;你可以通过几种方式来设置字体样式和高度。 1. 直接在<el-input>组件上使用style属性 你可以直接在<el-input&…...

并发解析hea,转为pdf格式

由于每次解析一个heap需要时间有点久&#xff0c;就写了一个自动解析程pdf的一个脚本。 down_lib.sh是需要自己写的哦&#xff0c;主要是用于下载自己所需程序的库&#xff0c;用于解析heap。 #!/bin/bash# 优化版通用解析脚本&#xff08;并发加速&#xff09;&#xff1a;批…...

【C语言】详解 指针

前言&#xff1a; 在学习指针前&#xff0c;通过比喻的方法&#xff0c;让大家知道指针的作用。 想象一下&#xff0c;你在一栋巨大的图书馆里找一本书。如果没有书架编号和目录&#xff0c;这几乎是不可能完成的任务。 在 C 语言中&#xff0c;指针就像是图书馆的索引系统&…...

RabbitMQ仲裁队列高可用架构解析

#作者&#xff1a;闫乾苓 文章目录 概述工作原理1.节点之间的交互2.消息复制3.共识机制4.选举领导者5.消息持久化6.自动故障转移 集群环境节点管理仲裁队列增加集群节点重新平衡仲裁队列leader所在节点仲裁队列减少集群节点 副本管理add_member 在给定节点上添加仲裁队列成员&…...

刚出炉热乎的。UniApp X 封装 uni.request

HBuilder X v4.66 当前最新版本 由于 uniapp x 使用的是自己包装的 ts 语言 uts。目前语言还没有稳定下来&#xff0c;各种不支持 ts 各种报错各种不兼容问题。我一个个问题调通的&#xff0c;代码如下&#xff1a; 封装方法 // my-app/utils/request.uts const UNI_APP_BASE…...

Apache Kafka 实现原理深度解析:生产、存储与消费全流程

Apache Kafka 实现原理深度解析&#xff1a;生产、存储与消费全流程 引言 Apache Kafka 作为分布式流处理平台的核心&#xff0c;其高吞吐、低延迟、持久化存储的设计使其成为现代数据管道的事实标准。本文将从消息生产、持久化存储、消息消费三个阶段拆解 Kafka 的核心实现原…...

Python 训练营打卡 Day 41

简单CNN 一、数据预处理 在图像数据预处理环节&#xff0c;为提升数据多样性&#xff0c;可采用数据增强&#xff08;数据增广&#xff09;策略。该策略通常不改变单次训练的样本总数&#xff0c;而是通过对现有图像进行多样化变换&#xff0c;使每次训练输入的样本呈现更丰富…...

leetcode付费题 353. 贪吃蛇游戏解题思路

贪吃蛇游戏试玩:https://patorjk.com/games/snake/ 问题描述 设计一个贪吃蛇游戏,要求实现以下功能: 初始化游戏:给定网格宽度、高度和食物位置序列移动操作:根据指令(上、下、左、右)移动蛇头规则: 蛇头碰到边界或自身身体时游戏结束(返回-1)吃到食物时蛇身长度增加…...

CCPC dongbei 2025 I

题目链接&#xff1a;https://codeforces.com/gym/105924 题目背景&#xff1a; 给定一个二分图&#xff0c;左图编号 1 ~ n&#xff0c;右图 n 1 ~ 2n&#xff0c;左图的每个城市都会与右图的某个城市犯冲&#xff08;每个城市都只与一个城市犯冲&#xff09;&#xff0c;除…...

系统性学习C语言-第十三讲-深入理解指针(3)

系统性学习C语言-第十三讲-深入理解指针&#xff08;3&#xff09; 1. 数组名的理解2. 使用指针访问数组3. ⼀维数组传参的本质4. 冒泡排序5. ⼆级指针 6. 指针数组7. 指针数组模拟二维数组 1. 数组名的理解 在上⼀个章节我们在使用指针访问数组的内容时&#xff0c;有这样的代…...

代理模式核心概念

代理模式核心概念 代理模式是一种结构型设计模式&#xff0c;通过创建一个代理对象来控制对原始对象的访问。主要分为两类&#xff1a; 一、静态代理 (Static Proxy) 定义&#xff1a;在编译期确定代理关系的模式&#xff0c;代理类和目标类都需要实现相同的接口。 核心特点…...

uni-app学习笔记十五-vue3页面生命周期(二)

onShow&#xff1a;用于监听页面显示&#xff0c;页面每次出现在屏幕上都触发&#xff0c;包括从下级页面点返回露出当前页面&#xff1b; onHide:监听页面隐藏&#xff0c;当离开当前页面时触发。 示例代码&#xff1a; <template><view>姓名&#xff1a;{{nam…...

贪心算法实战篇2

文章目录 前言序列问题摆动序列单调递增的数字 贪心解决股票问题买卖股票的最佳时机II 两个维度权衡问题分发糖果根据身高重建队列 前言 今天继续带大家进行贪心算法的实战篇2&#xff0c;本章注意来解答一些运用贪心算法的中等的问题&#xff0c;大家好好体会&#xff0c;怎么…...

Java 大视界 -- Java 大数据机器学习模型在元宇宙虚拟场景智能交互中的关键技术(239)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…...

Flask中关于app.url_map属性的用法

目录 一、app.url_map 是什么? 二、可以查看哪些信息? 三、示例:打印所有路由 四、结合 url_for() 使用 五、常见用途场景 六、结合 Flask CLI 使用 总结 app.url_map 是 Flask 中非常重要的一个属性,用于查看或操作整个应用的 URL 路由映射表(routing map)。它展…...