• 九校联考-DL24凉心模拟Day1T1 餐馆(restaurant)


    1.1 题目背景

    铜企鹅是企鹅餐馆的老板,他正在计划如何使得自己本年度收益增加。

    1.2 题目描述

    共有n 种食材,一份食材i 需要花 (t_i) 小时不间断地进行播种,施肥,直至收获。当然,一份食材i 是可以直接卖掉得到 (w_i) 块钱的。
    招牌菜共有m 种,一份招牌菜i 需要消耗一定的食材,花 (T_i) 小时不间断地来烹饪,叫卖,并最终卖出得到 (W_i) 块钱。
    整个季度换算下来一共有(T_{max}) 小时可供你使用,铜企鹅需要在这期间赚到最多的钱,这样他才有足够多的钱来steam 剁手,或者氪金手游

    1.3 格式

    1.3.1 输入格式

    第一行一个整数T,表示数据组数。
    一行三个整数n; m; (T_{max}),含义如题所示。
    接下来n行,每行两个整数 (t_i) ; (w_i),含义如题所示。
    接下来m行,每行两个整数 (T_i) ; (W_i),含义如题所示。
    接下来m行,每行n 个整数,第j 个数 (d_j)表示当前招牌菜需要 (d_j) 个食材j。

    1.3.2 输出格式

    对于每组数据,输出一行一个整数,表示你所能赚到的最多的钱。

    1.4 样例

    1.4.1 样例输入

    3
    1 1 48
    2 2000
    9 21864
    54
    4 46
    17 52
    4 36
    5 43
    16 62
    9 31659
    1 20431
    4 623
    1 11961
    4 5 3 5
    5 4 3 4
    3 3 3 3
    4 4 5 5
    10 0 48
    10 41
    18 48
    2 14
    22 65
    12 77
    7 48
    4 85
    2 61
    24 85
    8 34

    1.4.2 样例输出

    53728
    410
    1464

    1.5 数据范围

    Subtask 分值 n m T
    1 3 1 1 0
    2 20 1 1 5
    3 10 4 4 5
    4 17 2000 0 5
    5 50 2000 2000 4

    对于100% 的数据,保证0 < t_i ; T_i T_max 5000; 0 w_i;W_i 109,
    每份招牌菜使用的食材的个数总数不超过10^5。

    第一眼以为是树形dp(最近做多了...)写完后面的暴力回来先写了subtask4的完全背包,然后就发现较高级的物品和基础物品没啥区别。。直接把对应的原材料所需时间加到高级物品上就好了

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    long long wei[4001],dp[5001],va[4001];
    long long read() {
    	int ret=0;
    	char c;
    	c=getchar();
    	while(c>'9'||c<'0') {
    		c=getchar();
    	}
    	while(c>='0'&&c<='9') {
    		ret=ret*10+c-'0';
    		c=getchar();
    	}
    	return ret;
    }
    int main() {
    	long long t;
    	t=read();
    	while(t--) {
    		long long n,m,T;
    		n=read();
    		m=read();
    		T=read();
    		memset(wei,0,sizeof(wei));
    		memset(dp,0,sizeof(dp));
    		memset(va,0,sizeof(va));
    		for(int i=1; i<=n; i++) {
    			wei[i]=read();
    			va[i]=read();
    		}
    		for(int i=1; i<=m; i++) {
    			wei[n+i]=read();
    			va[n+i]=read();
    		}
    		for(int i=1; i<=m; i++) {
    			for(int j=1; j<=n; j++) {
    				int x;
    				x=read();
    				wei[n+i]+=x*wei[j];
    			}
    		}
    		for(int i=1; i<=n+m; i++) {
    			for(int j=wei[i]; j<=T; j++) {
    				dp[j]=max(dp[j],dp[j-wei[i]]+va[i]);
    			}
    		}
    		printf("%lld
    ",dp[T]);
    	}
    	return 0;
    }
    
  • 相关阅读:
    使用MyBatis时接收值和返回值选择Map类型或者实体类型
    如何在开发时部署和运行前后端分离的JavaWeb项目
    6月22日项目CodeReview问题及总结
    【转载】CSRF攻击及其应对之道
    【转载】MySQL事务以及SELECT ... FOR UPDATE的使用
    win10打开SQLServer, SQL Server 配置管理器
    iframe标签和frame标签异同
    8款让你耳目一新的软件开发工具
    快速开发平台的比较
    CSDN:Java Web 开发平台 WebBuilder 专访
  • 原文地址:https://www.cnblogs.com/shulker/p/9609197.html
Copyright © 2020-2023  润新知