您的位置:首页 > 其它

20151018_Vampire

2015-10-18 14:51 155 查看
Vampire

题目描述

Vampire 是一只吸血鬼,他每天必须吸满一定量的鲜血才能得以

生存。

他来到了 Rivendell 的鲜血食物商店,Rivendell 店长给他了一

份长长的列表,向他展示了 n 种富含鲜血的食物,这些食物分成许多

种类,有不同的名字,每个食物都有价格和它的鲜血含量。

现在 Vampire 手中有 m 元,他想要品尝所有种类的食物各一个,

并且他想使得他所品尝的所有食物中鲜血含量最少的尽可能大。

输入数据

输入数据的第一行是两个整数,食物个数 n 和 Vampire 的资金 m。

接下来 n 行,每行描述一个食物,分别是种类 type、名称 name、

价格 p 和鲜血含量 v,type 和 name 的长度均不超过 30 个字符。

输出数据

输出数据只有一行,如果能够符合 Vampire 的需求,就输出他品

尝的食物中鲜血含量最少的最大值。否则输出 orzVa。

样例

vampire.in

10 800

Drinkup BloodyMarie10 66 5

Drinkup BloodyMarie20 103 7

Drinkdown Cappuccino1 35 3

Drinkdown Cappuccino2 88 6

Linkout duang 52 10

Cutred CA 54 10

Cutred Ca 99 12

Dessert fish 157 5

Dessert Tiramisu 293 12

YYY Shallwe 18 12

vampire.out

6

数据范围

对于 30%数据,保证 1<=n<=10。

对于 100%数据保证

1<=n<=1000,

1<=m<=10^9,

1<=pi,qi<=10^6。

解题思路qwq

首先输入存储类型

统计每种类型个数

对权值进行排序

直接dfs(),因为进行过排序所以只要满足条件输出结果即可

#include<cstdio>
#include<cstring>
#include<climits>
#include<algorithm>
#include<iostream>
using namespace std;
int n,m,kk,ff;
bool flag=false;
char type[1005][30];
int k[1005];
struct food
{
int p,v;
}p[1005][1005];
void creat(char a[],char b[],int pp,int vv);
void find(char a[]);
void sort_food();
void bfs(int type,int pp,int vv);
int comp(food x,food y);
int comp(food x,food y)
{
if(x.v>y.v) return 1;
if(x.v==y.v&&x.p<y.p) return 1;
return 0;
}
int find_type(char a[])
{
if(kk!=0)
for(int i=1;i<=kk;i++)
{
if(strcmp(a,type[i])==0)
return i;
}
kk++;
for(int i=0;i<strlen(a);i++) type[kk][i]=a[i];
return kk;
}
void creat(char a[],char b[],int pp,int vv)
{
int q=find_type(a);
k[q]++;
p[q][k[q]].p=pp;
p[q][k[q]].v=vv;
}
void sort_food()
{
for(int i=1;i<=n;i++)
sort(p[i]+1,p[i]+k[i]+1,comp);
}
void dfs(int type,int pp,int minv)
{
if(flag) return;
if(type==kk+1&&pp<=m)
{
printf("%d",minv);flag=true;
return;
}
if(pp>m) return;
for(int i=1;i<=k[type];i++)
{
dfs(type+1,pp+p[type][i].p,min(p[type][i].v,minv));
if(flag) return;
}
return;
}
int main()
{
freopen("vampire.in","r",stdin);
freopen("vampire.out","w",stdout);
scanf("%d%d",&n,&m);
char a[30],b[30];int pp,vv;
for(int i=1;i<=n;i++)
{
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
cin>>a>>b;scanf("%d%d",&pp,&vv);
creat(a,b,pp,vv);
}
sort_food();
int q=0;
for(int i=1;i<=kk;i++)
q+=p[i][k[i]].p;
if(q>m){printf("orzVa");return 0;}
dfs(1,0,INT_MAX);
if(!flag) printf("orzVa");
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息