码迷,mamicode.com
首页 > 其他好文 > 详细

bzoj 3824: [Usaco2014 Dec]Guard Mark【状压dp】

时间:2018-09-08 21:11:01      阅读:131      评论:0      收藏:0      [点我收藏+]

标签:++   状态   iostream   转移   amp   没有   i++   include   ==   

设f[s]为已经从上到下叠了状态为s的牛的最大稳定度,转移的话枚举没有在集合里并且强壮度>=当前集合牛重量和的用min(f[s],当前放进去的牛还能承受多种)来更新,高度的话直接看是否有合法集合的高度达到要求即可

#include<iostream>
#include<cstdio>
using namespace std;
const int N=25;
int n,m,h[N],w[N],a[N],f[2000005],ans=-1;
int main()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
        scanf("%d%d%d",&h[i],&w[i],&a[i]);
    for(int i=0,len=(1<<n)-1;i<=len;i++)
        f[i]=-1;
    f[0]=1e9;
    for(int s=0,len=(1<<n)-1;s<=len;s++)
        if(f[s]!=-1)
        {
            int we=0,he=0;
            for(int i=1;i<=n;i++)
                if(s&(1<<(i-1)))
                    we+=w[i],he+=h[i];//cerr<<s<<" "<<f[s]<<" "<<we<<" "<<he<<endl;
            if(he>=m)
                ans=max(ans,f[s]);
            for(int i=1;i<=n;i++)
                if(!(s&(1<<(i-1)))&&a[i]>=we)
                    f[s|(1<<(i-1))]=max(f[s|(1<<(i-1))],min(f[s],a[i]-we));
        }
    if(ans==-1)
        puts("Mark is too tall");
    else
        printf("%d\n",ans);
    return 0;
}

bzoj 3824: [Usaco2014 Dec]Guard Mark【状压dp】

标签:++   状态   iostream   转移   amp   没有   i++   include   ==   

原文地址:https://www.cnblogs.com/lokiii/p/9610184.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!