JSOI 2008 魔兽地图
题目描述
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 魔兽地图的更多相关文章
- JSOI 2008 【魔兽地图】
其实这题是我从noip前就开始做的...那个时候打的Pascal,一直TLE,转了C++之后我又写了一遍,A了... 辛酸史: 题目描述: DotR (Def ...
- 【BZOJ-1017】魔兽地图DotR 树形DP + 背包
1017: [JSOI2008]魔兽地图DotR Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1566 Solved: 705[Submit][S ...
- 1017: [JSOI2008]魔兽地图DotR - BZOJ
Description DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Anc ...
- BZOJ 1017 魔兽地图
Description DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Anc ...
- BZOJ [JSOI2008]魔兽地图DotR
1017: [JSOI2008]魔兽地图DotR Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1243 Solved: 532[Submit][S ...
- 【百度地图API】如何制作一张魔兽地图!!——CS地图也可以,哈哈哈
原文:[百度地图API]如何制作一张魔兽地图!!--CS地图也可以,哈哈哈 摘要: 你玩魔兽不?你知道如何做一张魔兽地图不?! 快来看此文吧! ---------------------------- ...
- [BZOJ]1017 魔兽地图DotR(JSOI2008)
BZOJ第一页做着做着就能碰到毒题,做到BZOJ1082小C就忍了,没想到下一题就是这种东西.这种题目不拖出来枭首示众怎么对得起小C流逝的青春啊. Description DotR (Defense ...
- [JSOI2008]魔兽地图(树形dp)
DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA (Defense of the Ancients) Allst ...
- 【BZOJ1017】[JSOI2008]魔兽地图(动态规划)
[BZOJ1017][JSOI2008]魔兽地图(动态规划) 题面 BZOJ 洛谷 题解 状态设一下,\(f[i][j][k]\)表示第\(i\)个物品,有\(j\)个用于合成,总花费为\(k\)的最 ...
随机推荐
- 2019_8_1python
#函数 #函数是用来重复使用哒 #定义函数套路 ''' 1.首先要会写出裸代码,然后看看哪里是重复需要使用的 2.接下来将需要重复使用的代码转换成参数,带入到函数中 函数格式 def funcName ...
- mybatis自动生成代码工具(逆向工程)
MyBatis自动生成实体类(逆向工程) MyBatis属于一种半自动的ORM框架,它需要我们自己编写sql语句和映射文件,但是编写映射文件和sql语句很容易出错,所以mybatis官方提供了Gene ...
- 关于vsphere exsi安装时遇到的问题
我在虚拟机上安装vsphere 6.0的时候,在安装的过程中报错,出现了如下的内容. Error loading /tools.t00 Compressed MD5: Decompressed MD5 ...
- Python with语句的概率,不多说了直接上代码!
python中的with语句用于访问资源.它确保执行指定的__exit__(“清理”)操作,而不管释放被访问资源的处理过程中的错误或异常,例如读取和写入文件后自动关闭.线程中锁的自动获取和释放等. p ...
- Android Android Studio 如何导出 Jar 给 Unity 使用
大致步骤如下: 1.创建新的 Android Studio 工程 2.为此 Android Studio 工程创建 Android Library 类库(也就是一个 Module)(后面就是用它生成 ...
- delphi xe10 消息操作
//消息提醒(从手机屏幕顶部向下滑动,出现的提示消息) NotificationC: TNotificationCenter; procedure TNotificationsForm.btnSend ...
- Delphi 数学函数:常用的几个数学函数(Power、Abs、Int、Trunc、Round、Frac、sqr、sqrt)
Delphi 常用的几个数学函数 1 Power函数,求次方 定义:function Power(X,Y): (Same type as parameter); 说明:X可以是整型,也可以是实型:返回 ...
- 线性dp(记忆化搜索)——cf953C(经典好题dag和dp结合)
非常好的题!和spoj 的 Mobile Service有点相似,用记忆化搜索很容易解决 看了网上的题解,也是减掉一维,刚好可以开下数组 https://blog.lucien.ink/archive ...
- idea和eclipse快捷键对比(转)
分类 功能点 Eclipse快捷键 IDEA快捷键 搜索 搜索文本 Ctrl + F Ctrl + F Ctrl + R 查找替换 Alt + P/A 逐个/全部替换 Alt + F3 查找当前选中词 ...
- [JZOJ 5791] 阶乘
题意:求一个最小的\(m\),保证\(\prod a[i] * x = m!\) 思路: 考虑\(m!\)里面有多少个东西?? \(m\)个. 且是一个排列. 那么求一个最小的\(m\)使得前面的式子 ...