poj 2642 The Brick Stops Here(二维0/1背包)

简介: 点击打开链接poj 2642 思路: 0/1背包 分析: 1 题目给定n个物品,并且每个物品只有两种的选择很明显就是0/1背包的特性。 2 题目给定c个客户的要求,每一个客户都要求最后金子的平均浓度在min~max这个区间,并且每个客户要...

点击打开链接poj 2642

思路: 0/1背包
分析:
1 题目给定n个物品,并且每个物品只有两种的选择很明显就是0/1背包的特性。
2 题目给定c个客户的要求,每一个客户都要求最后金子的平均浓度在min~max这个区间,并且每个客户要m个物品
3 我们可以认为是客户选取了m个物品总的浓度在m*min~m*max这个区间,那么我们定义dp[i][k][j]表示前i个物品选k个放入浓度为j的背包,那么dp[i][j][k] = min(dp[i-1][k][j] , dp[i-1][k-1][j-v[i]]+w[i]);由于三维的复杂度很大,我们必须要进行降维,对于背包的降维来说都是通过逆序枚举得到


代码:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

const int INF = 0x3f3f3f3f;
const int N = 25;
const int MAX = 210;
const int MAXN = 1010*N;

int n , c , m , minV , maxV;
int v[MAX] , w[MAX] , dp[N][MAXN];

void solve(){
    memset(dp , INF , sizeof(dp));
    dp[0][0] = 0;

    for(int i = 1 ; i <= n ; i++){
        for(int k = N-1 ; k >= 1 ; k--){
            for(int j = MAXN-1 ; j >= v[i] ; j--)
                dp[k][j] = min(dp[k][j] , dp[k-1][j-v[i]]+w[i]); 
        }
    }
}

int main(){
    scanf("%d" , &n);
    for(int i = 1 ; i <= n ; i++)
        scanf("%d%d" , &v[i] , &w[i]);
    solve(); 
    scanf("%d" , &c);
    while(c--){
        scanf("%d%d%d" , &m , &minV , &maxV); 
        int ans = INF;
        for(int k = m*minV ; k <= m*maxV ; k++)
            ans = min(ans , dp[m][k]);
        if(ans == INF)
            puts("impossible");
        else
            printf("%d\n" , ans);
    }
    return 0;
}



目录
相关文章
|
关系型数据库 MySQL Java
SSM整合流程(整合配置、功能模块开发、接口测试)
SSM整合流程(整合配置、功能模块开发、接口测试)
295 0
|
JSON 自然语言处理 前端开发
golang在线词典
golang在线词典
112 0
|
缓存 负载均衡 算法
xv6(16) 进程二:调度算法
进程二:调度算法
240 0
xv6(16)  进程二:调度算法
|
存储 编译器 C语言
【C++初阶】类和对象(上)
上两篇文章我们对C++有了初步的认识,不知道大家看完后有没有很大的收获,今天我们继续深入C++的学习,探讨新的问题——类和对象。
沟通 节选自《闻缺陷则喜》(此书可免费下载)
沟通 节选自《闻缺陷则喜》(此书可免费下载)
|
分布式计算 Java Linux
Flink1.13架构全集| 一文带你由浅入深精通Flink方方面面(二)
Flink1.13架构全集| 一文带你由浅入深精通Flink方方面面
434 0
Flink1.13架构全集| 一文带你由浅入深精通Flink方方面面(二)
|
存储 安全 Java
Java-String类
字符串的基本操作 public String substring(int beginIndex,int endIndex):从字符串的下标beginIndex到endIndex生成一个子字符串 public String substring(int beginIndex)
|
算法 C++
详细实例说明+典型案例实现 对枚举法进行全面分析 | C++
简单的来说,算法就是用计算机程序代码来实现数学思想的一种方法。学习算法就是为了了解它们在计算机中如何演算,以及在当今的信息时代,它们是如何在各个层面上影响我们的日常生活的,从而提高我们的逻辑思维能力和处理实际问题的能力。善用算法、巧用算法,是培养程序设计逻辑的重中之重,许多实际的问题都可用多个可行的算法来解决, 但是要从中找出最优的解决算法却是一项挑战。
367 0
详细实例说明+典型案例实现 对枚举法进行全面分析 | C++
|
前端开发 JavaScript 数据库
JS案例:触底懒加载
JS案例:触底懒加载
387 0
JS案例:触底懒加载
|
监控 安全 机器人
Hunter狩猎者夹子机器人系统开发丨现成案例
区块链系统由无数节点构成,这些节点类似于一台tai.独立工作的计算机,当需要记账的时候,每一个节点都会参与竞争,系统会在一段时间内选出合适的节点来记账,而这个节点就会在数据区块中记录下近期发生的数据变化,记录完成后,节点就会把这个数据区块发送给其他节点,其他节点首先会核实数据,数据无误的话,就会把这个数据区块也放入自己的账本当中,于是系统里的所有节点都拥有一个完全一样的数据区块,即账本。 这种记账方式被称为区块链技术或者分布式总账技术
Hunter狩猎者夹子机器人系统开发丨现成案例