状态压缩 HDU1074

时间:2025-01-23 22:36:56

t组数据

n门课程 底限 完成要几天

dp[i] 表示i的二进制数中  1 对应位置课程 完成  最少扣多少分 完成的时间 记录一下怎么下来的

1->2^n 列举

(1<<n)   -1 就是全部都是1  然后输出即可

#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<stack> using namespace std; #define inf 100000000 struct node
{
char z[];
int da,ta; }x[];
struct node1
{
int time,pa,sc,now; }dp[<<]; bool cmp(node a,node b)
{
return strcmp(a.z,b.z)<;
}
stack<int>s; int main()
{
int t;
scanf("%d",&t);
while(t--)
{
int n;
scanf("%d",&n);
for(int i=;i<n;i++)
scanf("%s%d%d",x[i].z,&x[i].da,&x[i].ta);
sort(x,x+n,cmp);
int en=<<n; for(int i=;i<=en;i++)
{
dp[i].sc=inf;
for(int j=n-;j>=;j--)
{
int tem=<<j;
if(i&tem)
{
int past=i-tem;
int st=dp[past].time+x[j].ta-x[j].da;
if(st<)
st=;
if(st+dp[past].sc<dp[i].sc)
{
dp[i].sc=st+dp[past].sc;
dp[i].pa=past;
dp[i].now=j;
dp[i].time=dp[past].time+x[j].ta;
}
}
}
} en--;
printf("%d\n",dp[en].sc);
while(en)
{
s.push(dp[en].now);
en=dp[en].pa;
}
while(!s.empty())
{
int now=s.top();
printf("%s\n",x[now].z);
s.pop();
}
} return ;
}