首页 > 代码库 > BZOJ 2073
BZOJ 2073
思路:
状压DP 枚举子集
//By SiriusRen #include <cstdio> #include <cstring> #include <algorithm> using namespace std; const int N=1<<17; int w,n,t[N]; struct Node{int w,t;}node[N]; int main(){ scanf("%d%d",&w,&n); memset(t,0x3f,sizeof(t)); for(int i=0;i<n;i++)scanf("%d%d",&node[i].t,&node[i].w); for(int i=1;i<(1<<n);i++){ int temp=0,tempw=0; for(int j=0;j<n;j++)if(i&(1<<j))temp=max(temp,node[j].t),tempw+=node[j].w; if(tempw<=w)t[i]=temp; } for(int i=1;i<(1<<n);i++){ for(int j=i;j;j=(j-1)&i) t[i]=min(t[i],t[j]+t[i^j]); }printf("%d\n",t[(1<<n)-1]); }
BZOJ 2073
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。