背包问题基础

直接贴代码

/**
 * 背包问题
 * @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;
	}

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值