zoukankan      html  css  js  c++  java
  • POJ 3624 Charm Bracelet 背包问题的解决方案

    最简单的背包问题,标题应该是除了背包测试中心:您无法打开二维数组。我还没有开的二维。光看数据是不可能的。

    太大。

    有两种方法来提高全省内存DP:

    1 所谓卷的阵列

    2 反向表


    久没做背包DP,突然认为这样的背包问题非常easy了。

    以下给出两种解法:

    1 calBag()是滚动数组

    2 calBag2()是逆向填表


    #pragma once
    #include <stdio.h>
    #include <stdlib.h>
    #include <vector>
    using namespace std;
    
    const int MAX_W = 12881;
    const int MAX_N = 3403;
    int N, M;//M是total weight
    int wei[MAX_N];
    int desi[MAX_N];
    int tbl[MAX_W];
    
    int calBag2()
    {
    	memset(tbl, 0, sizeof(int)*(M+1));
    	for (int i = 1; i <= N; i++)
    	{
    		for (int j = M; j >= wei[i]; j--)
    			tbl[j] = max(tbl[j], tbl[j-wei[i]]+desi[i]);
    	}
    	return tbl[M];	
    }
    
    int calBag()
    {
    	vector<vector<int> > tbl(2, vector<int>(M+1));
    	bool id = true;
    	for (int i = 1; i <= N; i++)
    	{
    		for (int j = 1; j < wei[i] && j <= M; j++) tbl[id][j] = tbl[!id][j];
    		for (int j = wei[i]; j <= M; j++)
    		{
    			tbl[id][j] = max(tbl[!id][j], tbl[!id][j-wei[i]]+desi[i]);
    		}//注意都是上一列的数据往下拉,都是!id数列比較
    		id = !id;
    	}
    	return tbl[!id][M];
    }
    
    int main()
    {
    	while (scanf("%d %d", &N, &M) != EOF)
    	{
    		for (int i = 1; i <= N; i++)
    		{
    			scanf("%d %d", &wei[i], &desi[i]);
    		}
    		printf("%d
    ", calBag2());
    	}
    	return 0;
    }
    
    
    




    版权声明:笔者心脏靖,景空间地址:http://blog.csdn.net/kenden23/,可能不会在未经作者同意转载。

  • 相关阅读:
    显因子模型简介
    关联规则中最小支持度和最小置信度
    Matlab读取音频数据
    初识禁忌搜索算法
    Word中将图表变为表格
    明尼苏达推荐系统导论(第一课 欢迎来到RS)
    python复杂网络分析库NetworkX
    python使用zlib实现压缩与解压字符串
    PostgreSQL 对字段大小写敏感
    pycharm快捷键及一些常用设置
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4650614.html
Copyright © 2011-2022 走看看