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;
}



目录
相关文章
|
缓存 负载均衡 算法
xv6(16) 进程二:调度算法
进程二:调度算法
312 0
xv6(16)  进程二:调度算法
|
弹性计算 数据库
ECS使用有感
我是一名即将步入社会的大学生,随着网络法等相关专业知识的学习愈发强烈。查询资料时,常常会浏览到制作精美的个人站,因此产生了建设自己个人站的设想,但是由于业余时间少之甚少,同时听闻购买域名与服务器的价格不菲,因此计划一直未能实现
|
22小时前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
10天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
4天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
430 191
|
3天前
|
数据采集 消息中间件 人工智能
跨系统数据搬运的全方位解析,包括定义、痛点、技术、方法及智能体解决方案
跨系统数据搬运打通企业数据孤岛,实现CRM、ERP等系统高效互通。伴随数字化转型,全球市场规模超150亿美元,中国年增速达30%。本文详解其定义、痛点、技术原理、主流方法及智能体新范式,结合实在Agent等案例,揭示从数据割裂到智能流通的实践路径,助力企业降本增效,释放数据价值。