题目描述

DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Ancients) Allstars。

DotR里面的英雄只有一个属性——力量。他们需要购买装备来提升自己的力量值,每件装备都可以使佩戴它的英雄的力量值提高固定的点数,所以英雄的力量值等于它购买的所有装备的力量值之和。装备分为基本装备和高级装备两种。基本装备可以直接从商店里面用金币购买,而高级装备需要用基本装备或者较低级的高级装备来合成,合成不需要附加的金币。装备的合成路线可以用一棵树来表示。

比如,Sange and Yasha的合成需要Sange,Yasha和Sange and Yasha Recipe Scroll三样物品。其中Sange又要用Ogre Axe, Belt of Giant Strength和 Sange Recipe Scroll合成。每件基本装备都有数量限制,这限制了你不能无限制地合成某些性价比很高的装备。

现在,英雄Spectre有M个金币,他想用这些钱购买装备使自己的力量值尽量高。你能帮帮他吗?他会教你魔法Haunt(幽灵附体)作为回报的。

输入输出格式

输入格式:

第一行包含两个整数,N (1 <= n <= 51) 和 m (0 <= m <= 2,000)。分别表示装备的种类数和金币数。装备用1到N的整数编号。

接下来的N行,按照装备1到装备n的顺序,每行描述一种装备。

每一行的第一个非负整数表示这个装备贡献的力量值。

接下来的非空字符表示这种装备是基本装备还是高级装备,A表示高级装备,B表示基本装备。如果是基本装备,紧接着的两个正整数分别表示它的单价(单位为金币)和数量限制(不超过100)。如果是高级装备,后面紧跟着一个正整数C,表示这个高级装备需要C种低级装备。后面的2C个数,依次描述某个低级装备的种类和需要的个数。

输出格式:

第一行包含一个整数S,表示最多可以提升多少点力量值。

输入输出样例

输入样例#1: 复制

10 59

5 A 3 6 1 9 2 10 1

1 B 5 3

1 B 4 3

1 B 2 3

8 A 3 2 1 3 1 7 1

1 B 5 3

5 B 3 3

15 A 3 1 1 5 1 4 1

1 B 3 5

1 B 4 3

输出样例#1: 复制

33


//By Monster_Qi
#include<bits/stdc++.h> using namespace std;
const int MAXM = 2005;
const int MAXN = 55;
const int inf = 0x3f3f3f3f; struct Edge{
int nxt,to,val;
}edge[MAXN*MAXN];
//dp[x][i][j]表示以x为节点,i个用于合成,花费j元的最大收益。
int n,m,head[MAXN],cnt,dp[MAXN][MAXN*2][MAXM];
int L[MAXN],M[MAXN],war[MAXN];
//L[x]表示以x为根的子树最多合成几个,M[x]表示以x为根的子树最大花费。
int ans[MAXM],f[MAXM]; //ans[x]表示花费x元的最大收益,f[x]表示花费x元的局部最大收益。
bool vis[MAXN],used[MAXN]; inline void add(int bg,int ed,int w){
edge[++cnt].to=ed;
edge[cnt].val=w;
edge[cnt].nxt=head[bg];
head[bg]=cnt;
} inline void dfs(int x){
if(vis[x]) return;
vis[x]=1;
if(!head[x]){ //如果为叶节点。
L[x]=min(L[x],m/M[x]);
for(register int i=L[x];i>=0;i--) //枚举几个用来合成。
for(register int j=i;j<=L[x];j++) //枚举一共买了几个。
dp[x][i][M[x]*j]=war[x]*(j-i);
return;
}
L[x]=inf;
for(register int i=head[x];i;i=edge[i].nxt){
int v=edge[i].to;dfs(v);
L[x]=min(L[x],L[v]/edge[i].val);
M[x]+=edge[i].val*M[v];
}
L[x]=min(L[x],m/M[x]); //排除可能因钱不够的影响。
for(register int i=L[x];i>=0;i--){ //枚举买几个此物品。
memset(f,-0x3f,sizeof(f));
f[0]=0;
for(register int u=head[x];u;u=edge[u].nxt){
int v=edge[u].to;
for(register int j=m;j>=0;j--){ //枚举一共的花费。
int sum=-inf;
for(register int k=0;k<=j;k++){ //枚举以v为根的子树的花费。
sum=max(sum,f[j-k]+dp[v][edge[u].val*i][k]);
//其他物品的收益加上以v为根的子树的最大花费。
f[j]=sum;
}
}
}
for(register int j=0;j<=i;j++) //枚举有几个用来合成。
for(register int k=0;k<=m;k++) //枚举花费多少。
dp[x][j][k]=max(dp[x][j][k],f[k]+war[x]*(i-j));
}
} int main(){
scanf("%d%d",&n,&m);
memset(dp,-0x3f,sizeof(dp));
for(register int i=1;i<=n;i++){
scanf("%d",&war[i]);
char c;
cin>>c;
// cout<<c<<endl;
if(c=='B')
scanf("%d%d",&M[i],&L[i]);
else{
int nn;
scanf("%d",&nn);
for(register int j=1;j<=nn;j++){
int a,b;
scanf("%d%d",&a,&b);
add(i,a,b);
used[a]=1;
}
}
}
// for(register int i=1;i<=n;i++) cout<<used[i]<<endl;
for(register int i=1;i<=n;i++)
if(!used[i]){
dfs(i);
for(register int j=m;j>=0;j--) //枚举总共花了多少钱。
for(register int k=0;k<=j;k++) //枚举以i为根的子树的花费。
ans[j]=max(ans[j],ans[j-k]+dp[i][0][k]);
}
// for(register int i=1;i<=m;i++) cout<<ans[i]<<endl;
printf("%d\n",ans[m]);
return 0;
}

JSOI 2008 魔兽地图的更多相关文章

  1. JSOI 2008 【魔兽地图】

    其实这题是我从noip前就开始做的...那个时候打的Pascal,一直TLE,转了C++之后我又写了一遍,A了... 辛酸史:                      题目描述: DotR (Def ...

  2. 【BZOJ-1017】魔兽地图DotR 树形DP + 背包

    1017: [JSOI2008]魔兽地图DotR Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1566  Solved: 705[Submit][S ...

  3. 1017: [JSOI2008]魔兽地图DotR - BZOJ

    Description DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Anc ...

  4. BZOJ 1017 魔兽地图

    Description DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Anc ...

  5. BZOJ [JSOI2008]魔兽地图DotR

    1017: [JSOI2008]魔兽地图DotR Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1243  Solved: 532[Submit][S ...

  6. 【百度地图API】如何制作一张魔兽地图!!——CS地图也可以,哈哈哈

    原文:[百度地图API]如何制作一张魔兽地图!!--CS地图也可以,哈哈哈 摘要: 你玩魔兽不?你知道如何做一张魔兽地图不?! 快来看此文吧! ---------------------------- ...

  7. [BZOJ]1017 魔兽地图DotR(JSOI2008)

    BZOJ第一页做着做着就能碰到毒题,做到BZOJ1082小C就忍了,没想到下一题就是这种东西.这种题目不拖出来枭首示众怎么对得起小C流逝的青春啊. Description DotR (Defense ...

  8. [JSOI2008]魔兽地图(树形dp)

    DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Ancients) Allst ...

  9. 【BZOJ1017】[JSOI2008]魔兽地图(动态规划)

    [BZOJ1017][JSOI2008]魔兽地图(动态规划) 题面 BZOJ 洛谷 题解 状态设一下,\(f[i][j][k]\)表示第\(i\)个物品,有\(j\)个用于合成,总花费为\(k\)的最 ...

随机推荐

  1. GCloud SDK 遇到的错误记录

    eclipse 环境 1.调用 SetAppInfo 方法返回 -1 语音id 和 key 设置正确 ,各种检测都没问题 解决办法 把安卓工程目录下 obj 文件价删除 ,把sdk 替换成以前能用的老 ...

  2. Ubuntu桌面突然卡住,图形界面无反应

    1.可能等待几分钟,系统会自动反应过来.你可以选择等待几分钟. 2.绝大多数情况系统是不会反应过来的,这时候可以进入tty终端直接注销用户. (1)Ubuntu有6个tty终端,按住Ctrl+Alt+ ...

  3. 使用sql对比Mysql中数据库2个表结构

    比较两个数据表的结构 SELECT column_name, max( CASE WHEN table_name = 'table1' AND table_schema = 'db1' THEN 'Y ...

  4. springBoot项目mybatis中加入缓存

    1:maven: <!-- https://mvnrepository.com/artifact/net.sf.ehcache/ehcache-core --> <dependenc ...

  5. 一个简易h5涉及的ps技巧

    事实证明,很长时间不做,是会忘掉的呀,的呀,呀,啊~ 1.合并图层 CTRL+E合并多个图层 2.切片 3.导出 文件-------导出------存储为web所用格式-------->> ...

  6. 19. 接口(创建interface 继承implements)

    1.语法: interface 接口名{ 属性 抽象方法 } 2.实例: 3.注意: 1)类实现接口可以通过implements实现,实现接口的时候必须把接口中的所有方法实现,一个类可以实现多个接口. ...

  7. UDP部分

    IP地址:互联网协议地址,计算机的通行证.计算机在网络中的唯一身份标识.桥接:Ubuntu虚拟机 直接连到局域网NAT:网络地址转换点分十进制:192.168.14.115IP地址通常为4个字节,简称 ...

  8. 牛客多校第九场 J Symmetrical Painting 计算几何/扫描线

    题意: 平面上有几个宽度相同的矩形区域被涂黑了,让你找到一条横线横截若干个矩形,把这些黑色部分抠下来一部分使得它们以这条横线为对称轴,求能抠下来的最大面积. 题解: 在随着对称轴上移的过程中,必然有一 ...

  9. hdu多校第六场1005 (hdu6638) Snowy Smilel 线段树/区间最大和

    题意: 给定一个矩阵,矩阵上有若干点,每个点有正或负的权值,找一个方框框住一些点使得方框中点权值最大. 题解: 离散化横纵坐标,容易将这个问题转化为在矩阵上求最大和子矩阵的问题. 普通的n*n的矩阵的 ...

  10. KdPrint/DbgPrint and UNICODE_STRING/ANSI_STRING

    typedef struct _UNICODE_STRING { USHORT Length; USHORT MaximumLength; PWSTR Buffer; } UNICODE_STRING ...