[2016-03-28][HDU][1074][Doing Homework]

Posted 红洋

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[2016-03-28][HDU][1074][Doing Homework]相关的知识,希望对你有一定的参考价值。

  • 时间:2016-03-28 18:46:36 星期一

  • 题目编号:[2016-03-28][HDU][1074][Doing Homework]

  • 题目大意:给定n门科作业的期限时间和完成耗时,每科每超过一天就扣一份,求最少扣分数

  • 分析:n只有15,二进制枚举,状态压缩,枚举每种科目完成的状态,更新下一个状态,求最小值

  1. #include <cstring>
  2. #include <cstdio>
  3. using namespace std;
  4. const int maxstu = 1 << 16;
  5. struct Cource{
  6. char name[20];
  7. int d,c;
  8. }a[16];
  9. struct mstatus{
  10. int pre,cost,reduced,id;
  11. mstatus(int a = 0,int b = 0,int c = 0,int d = 0):cost(a),reduced(b),pre(c),id(d){};
  12. }dp[maxstu];
  13. int vis[maxstu];
  14. void print(int cur){
  15. if(dp[cur].pre == 0){
  16. printf("%s\n",a[ dp[cur].id ].name);
  17. return ;
  18. }
  19. print(dp[cur].pre);
  20. printf("%s\n",a[ dp[cur].id ].name);
  21. }
  22. int main(){
  23. int T;
  24. scanf("%d",&T);
  25. while(T--){
  26. int n;
  27. scanf("%d",&n);
  28. for(int i = 0;i < n;++i){
  29. scanf("%s%d%d",a[i].name,&a[i].d,&a[i].c);
  30. }
  31. memset(vis,0,sizeof(vis));
  32. dp[0] = mstatus(0,0,0,0);
  33. for(int i = 0;i < (1 << n) - 1;++i){
  34. for(int j = 0;j < n;++j){
  35. int cur = 1 << j;
  36. if((cur & i) == 0){
  37. int curcost = dp[i].cost + a[j].c;
  38. int curreduced = dp[i].reduced + (curcost <= a[j].d?0:curcost - a[j].d);
  39. int nxtstatus = cur | i;
  40. if(vis[nxtstatus]){
  41. if(curreduced < dp[nxtstatus].reduced){
  42. dp[nxtstatus] = mstatus(curcost,curreduced,i,j);
  43. }
  44. }else {
  45. vis[nxtstatus] = 1;
  46. dp[nxtstatus] = mstatus(curcost,curreduced,i,j);
  47. }
  48. }
  49. }
  50. }
  51. int ans = dp[(1 << n) - 1].reduced;
  52. printf("%d\n",ans);
  53. print((1 << n) - 1);
  54. }
  55. return 0;
  56. }




以上是关于[2016-03-28][HDU][1074][Doing Homework]的主要内容,如果未能解决你的问题,请参考以下文章

[2016-03-28][HDU][1078][FatMouse and Cheese]

[2016-03-28][HDU][1024][Max Sum Plus Plus]

hdu 1074 状态压缩

HDU1074

HDU1074 Doing Homework —— DP

HDU 1074:Doing Homework(状压DP)