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

动态规划入门之01背包变形嗑药

P1802 5 倍经验日 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

嗑药固然可耻,但是能让你快速变强   --鲁迅

手动滑稽,话归正题

动态规划之背包入门01背包模板_爱莉我老婆的博客-CSDN博客

这是01背包的模板,没看的可以去看看。

我们把药品总量看成一个背包,我们把打败每一人的药品消耗看成体积,那么就是说我们把这个物品装进背包会产生一个价值,不装进背包也会产生一个价值。那么我们在01背包的基础上改进,可以写出如下状态转移方程

for(c=1;c<=a;c++) {String[] bStrings=br1.readLine().split(" ");int e=Integer.parseInt(bStrings[0]);//输入打输时的价值(即装不进背包的价值)int f=Integer.parseInt(bStrings[1]);//(装进背包的价值)int g=Integer.parseInt(bStrings[2]);//物品所占的空间	for(d=b;d>=0;d--) {//枚举体积,由于我们采用一维压缩,所以倒序保证物品之多会被选择一件if(d>=g) {//体积达到,从不装第c个物品前c-1个物品里边选取放到容积为d的背包dp[d]=Math.max(dp[d]+e, dp[d-g]+f);//选择第c个物品,}else {dp[d]=dp[d]+e;//体积不够直接装装不了的价值}}
}

完整代码:


import java.awt.FontFormatException;
import java.io.BufferedReader; 
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.lang.reflect.AnnotatedWildcardType;
import java.math.BigInteger;
import java.net.DatagramPacket;
import java.sql.SQLIntegrityConstraintViolationException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashSet;
import java.util.LinkedList;
import java.util.Map;
import java.util.Objects;
import java.util.PriorityQueue;
import java.util.Scanner;
import java.util.Spliterator.OfPrimitive;
import java.util.function.IntToDoubleFunction;
import java.util.function.LongBinaryOperator;
import java.util.TreeMap;
import java.util.TreeSet;
import javax.management.relation.InvalidRelationTypeException;
import javax.print.attribute.standard.JobMessageFromOperator;
import javax.print.attribute.standard.JobPriority;
import javax.swing.plaf.ColorChooserUI;
import javax.swing.table.TableModel;
import javax.swing.text.TabSet;
import javax.xml.crypto.dsig.spec.DigestMethodParameterSpec;
public class Main {public static void main(String[] args) throws IOException  {
Scanner sc=new Scanner(System.in);
BufferedReader br1=new BufferedReader(new InputStreamReader(System.in));
PrintWriter pw1=new PrintWriter(System.out);
String[] aStrings=br1.readLine().split(" ");
int a=Integer.parseInt(aStrings[0]);
int b=Integer.parseInt(aStrings[1]);
dp=new long[b+1];int c,d;
for(c=1;c<=a;c++) {String[] bStrings=br1.readLine().split(" ");int e=Integer.parseInt(bStrings[0]);int f=Integer.parseInt(bStrings[1]);int g=Integer.parseInt(bStrings[2]);	for(d=b;d>=0;d--) {if(d>=g) {dp[d]=Math.max(dp[d]+e, dp[d-g]+f);}else {dp[d]=dp[d]+e;}}
}
System.out.println(5*dp[b]);}public static long[] dp;}

此题必须开long

http://www.lryc.cn/news/137405.html

相关文章:

  • 数据结构——栈和队列OJ题
  • 同态排序算法
  • “深入探索JVM内部机制:解析Java虚拟机的工作原理“
  • 为应用程序接入阿里云CDN优化网站访问速度
  • 索引设计规范
  • Appium 2安装与使用java对Android进行自动化测试
  • 小程序运营方式有哪些?如何构建小程序运营框架?
  • 【golang】for语句和switch语句
  • 三、数据库索引
  • 长时间带什么耳机最舒服,分享长时间佩戴舒服的耳机推荐
  • Yolov8小目标检测(1)
  • GPS定位漂移问题分析
  • 前端简介(HTML+CSS+JS)
  • List与String数组互转
  • MySQL中的数据类型
  • python多任务
  • c语言 - inline关键字(内联函数)
  • 如何在Ubuntu 18.04上安装PHP 7.4并搭建本地开发环境
  • 狭义相对论
  • 仓库使用综合练习
  • 如何在前端实现WebSocket发送和接收TCP消息(多线程模式)
  • VB.NET通过VB6 ActiveX DLL调用PowerBasic及FreeBasic动态库
  • 怎样不引入图片实现前端css实现x关闭按钮
  • SpringBoot实现文件下载的多种方式
  • uniapp简单版语音播放
  • 前端三剑客入门一文解决
  • php curl apache 超时 500错误
  • ValueError: too many values to unpack (expected 4)
  • 学习Vue过程中遇到的问题汇总
  • cloud_mall-notes03