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

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

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

手动滑稽,话归正题

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

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

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

java 复制代码
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;//体积不够直接装装不了的价值
		}
	}
}

完整代码:

java 复制代码
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

相关推荐
stillaliveQEJ1 小时前
【javaEE】Spring AOP(一)
java·spring·java-ee
麦兜*1 小时前
SpringBoot进阶:深入理解SpringBoot自动配置原理与源码解析
java·spring boot·spring·spring cloud
慕白Lee1 小时前
项目JDK17+SpringBoot3.0升级
java·ide·intellij-idea
程序员泡椒2 小时前
二分查找Go版本实现
数据结构·c++·算法·leetcode·go·二分
小雨下雨的雨2 小时前
Flutter鸿蒙共赢——墨染算法:柏林噪声与鸿蒙生态中的数字水墨意境
算法·flutter·华为·交互·harmonyos·鸿蒙
NAGNIP8 小时前
万字长文!回归模型最全讲解!
算法·面试
之歆8 小时前
Spring AI入门到实战到原理源码-MCP
java·人工智能·spring
知乎的哥廷根数学学派8 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
yangminlei8 小时前
Spring Boot3集成LiteFlow!轻松实现业务流程编排
java·spring boot·后端
qq_318121598 小时前
互联网大厂Java面试故事:从Spring Boot到微服务架构的技术挑战与解答
java·spring boot·redis·spring cloud·微服务·面试·内容社区