设为首页 加入收藏

TOP

hdu 2546 饭卡(背包)
2014-11-23 20:16:34 来源: 作者: 【 】 浏览:13
Tags:hdu 2546 饭卡 背包


设饭卡余额为total
此题经分析 可以得出:要求选出一些饭菜 时消费量尽量接近total-5元 然后再买一个饭菜 以达到透支。。。


可以证明 最后买的那个饭菜是饭菜中价值最大的.
证明


设a1 a2 a3...an-1 an 为各饭菜的价格 设an的价格最大



sum=total-5
a1+a2+a3+...an-2+an-1+an=M
a1+a2+a3+...+an-2+an-1=x1 最后加an (按5元为界限)此时超额(an-1)-(sum-x1)=an-sum+a1+a2+...+an-2+an-1元 1
a1+a2+a3+...+an-2+an=x2 最后加an-1(按5元为界限)此时超额(an)-(sum-x2)=(an-1)-sum+a1+a2+...+an-2+an元 2


1式-2式=2*((an)-(an-1))>0
所以1式超额更多
所以最后选价格最大的那个饭菜得证


此题注意一点: 如果余额total本身就少于5元 直接输出total 此时没法买东西了 这种特殊情况要判断


动态规划
01背包问题 背包总量为余额-5 每个背包价值和重量都为w

#include

#include
#include
#define max(a,b) a>b a:b
int cmp(const void *a,const void *b)
{
return *(int*)a-*(int*)b;
}
int main()
{
int n,a[5000],i,bb[5000],m,j;
while(scanf("%d",&n),n!=0)
{
memset(bb,0,sizeof(bb));
for(i=0;i scanf("%d",&a[i]);
scanf("%d",&m);
qsort(a,n,sizeof(a[0]),cmp);
if(m<5)
{
printf("%d\n",m);
continue;
}
memset(bb,0,sizeof(bb));
m=m-5;
bb[0]=0;
for(i=0;i {
for(j=m;j>=a[i];j--)
{
bb[j]=max(bb[j],bb[j-a[i]]+a[i]);
}
}
printf("%d\n",m+5-bb[m]-a[n-1]);
}
return 0;

}


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hdu 4643 GSM 计算几何 - 点线关.. 下一篇HDU 4648 Magic Pen 6

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C 内存管理 | 菜鸟教 (2025-12-26 20:20:37)
·如何在 C 语言函数中 (2025-12-26 20:20:34)
·国际音标 [ç] (2025-12-26 20:20:31)
·微服务 Spring Boot (2025-12-26 18:20:10)
·如何调整 Redis 内存 (2025-12-26 18:20:07)