背包问题基础

本文通过具体的代码实现,介绍了0-1背包问题与完全背包问题的解决方法,并提供了两种背包问题的具体算法实现,包括如何求解最大价值及恰好装满背包的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

直接贴代码

/**
 * 背包问题
 * @author 
 *
 */
public class PackDemo {
	/**
	 * V 最大容量
	 * 
	 */
	public static int V = 6;
	/**
	 * N 包个数
	 */
	public static int N = 3;
	/**
	 * packs[i][0]表示物品重量
	 * packs[i][1]表示物品价值
	 * i表示第i个物品 
	 * 
	 */
	int[][] packs = {
			{1,2},{4,2},{4,3}
	};

	public static void main(String[] args) {
		System.out.println("0-1背包问题解:" + new PackDemo().Pack1());
		System.out.println("完全背包问题解:" + new PackDemo().Pack2());
		PackDemo pd = new PackDemo();
		
		int value = pd.Pack3();
		if(value == Integer.MIN_VALUE)
			System.out.println("0-1背包问题解:无解" );
		System.out.println("0-1背包问题解:" + new PackDemo().Pack3());
		System.out.println("完全背包问题解:" + new PackDemo().Pack4());

	}
	
	/**
	 * 完全背包 恰好装满
	 * @return
	 */
	public int Pack4(){
		/**
		 * F[v]含义 表示容量为v的包中在给定的物品下可以获得最大价值
		 * 
		 */
		int[] F = new int[V + 1];
		
		F[0] = 0;
		for(int i = 1; i <= V; i++){
			F[i] = Integer.MIN_VALUE;
		}
		
		for(int i = 0; i < N; i++){
			CompletePackForTotal(F, packs[i][0], packs[i][1]);
		}
		return F[V];
	}
	
	private void CompletePackForTotal(int[] F, int C, int W){
		for(int v = C; v <= V; v++)
			F[v] = max(F[v], F[v - C] + W);
	}
	
	
	/**
	 * 01背包 恰好装满
	 * @return
	 */
	public int Pack3(){
		int[] F = new int[V + 1];
		F[0] = 0;
		for(int i = 1; i <= V; i++){
			F[i] = Integer.MIN_VALUE;
		}
		for(int i = 0; i < N; i++){
			ZeroOnePackForTotal(F, packs[i][0], packs[i][1]);
		}
		return F[V];
	}
	
	private void ZeroOnePackForTotal(int[] F, int C, int W){
		for(int v = V; v >= C; v--)
			F[v] = max(F[v], F[v - C] + W);
	}
	
	/**
	 * 完全背包
	 * @return
	 */
	public int Pack2(){
		/**
		 * F[v]含义 表示容量为v的包中在给定的物品下可以获得最大价值
		 * 
		 */
		int[] F = new int[V + 1];
		for(int i = 0; i <= V; i++){
			F[i] = 0;
		}
		for(int i = 0; i < N; i++){
			CompletePack(F, packs[i][0], packs[i][1]);
		}
		return F[V];
	}
	
	private void CompletePack(int[] F, int C, int W){
		for(int v = C; v <= V; v++)
			F[v] = max(F[v], F[v - C] + W);
	}
	
	
	/**
	 * 01背包
	 * @return
	 */
	public int Pack1(){
		int[] F = new int[V + 1];
		for(int i = 0; i <= V; i++){
			F[i] = 0;
		}
		for(int i = 0; i < N; i++){
			ZeroOnePack(F, packs[i][0], packs[i][1]);
		}
		return F[V];
	}
	
	private void ZeroOnePack(int[] F, int C, int W){
		for(int v = V; v >= C; v--)
			F[v] = max(F[v], F[v - C] + W);
	}
	
	private int max(int x, int y){
		return x > y ? x : y;
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值