• HDU4508 湫湫系列故事——减肥记I


       这题一开始看还以为是0,1背包问题,不过老师说过了完全背包就按照这个思路做.(虽然偷偷去百度了一下到底是不是,有点怀疑老师是不是记错了的说);

      顺便记下对一维数组方程的理解;

      for(int i =1;i<=n;i++)有n次就可以啦;//闭区间

      for(int j=b[i];j<=m;j++)//每进行一次循环,第i件物品数加1或者0;

      dp[j]=max(dp[j],dp[j-b[i]]+a[i]);//如果是最优解的话,先后顺序无所谓是不是;

      下面给出代码.嘻嘻.

    //这个在背包九讲里面也提到了,个人觉得蛮重要的;

    初始化的f数组事实上就是在没有任何物品可以放入背包时的合法状态。如果要求背包恰好装满,那么此时只有容量为0的背包可能被价值为0的nothing“恰好装满”,其它容量的背包均没有合法的解,属于未定义的状态,它们的值就都应该是-∞了。如果背包并非必须被装满,那么任何容量的背包都有一个合法解“什么都不装”,这个解的价值为0,所以初始时状态的值也就全部为0了。

     

     1 #define maxn 100005
     2 #include<iostream>
     3 using namespace std;
     4 int a[maxn],b[maxn],n,m,dp[maxn];
     5 int max(int a,int b)
     6 {
     7     return a>b?a:b;
     8 }
     9 int main()
    10 {
    11     //freopen("4508.txt","r",stdin);
    12     while(~scanf("%d",&n))
    13     {
    14         memset(a,0,sizeof(a));
    15         memset(b,0,sizeof(b));
    16         memset(dp,0,sizeof(dp));
    17         int i,j;
    18         for(i=1;i<=n;i++)
    19             scanf("%d %d",a+i,b+i);
    20         scanf("%d",&m);
    21         for(i=1;i<=n;i++)
    22             for(j=b[i];j<=m;j++)
    23                 dp[j]=max(dp[j],dp[j-b[i]]+a[i]);
    24             printf("%d ",dp[m]);
    25     }
    26     return 0;
    27 }
  • 相关阅读:
    【题解】NOI2014购票
    【题解】HEOI2013Eden 的新背包问题
    【题解】ZJOI2013蚂蚁寻路
    【题解】POI2014FAR-FarmCraft
    【题解】NOI2015寿司晚宴
    【题解】HNOI2018寻宝游戏
    省选算法学习-数据结构-虚树
    [HDU3516] Tree Construction [四边形不等式dp]
    [HDU3480] Division [四边形不等式dp]
    [POJ1160] Post Office [四边形不等式dp]
  • 原文地址:https://www.cnblogs.com/xiaoniuniu/p/3879405.html
Copyright © 2020-2023  润新知