1 条题解

  • 2
    @ 2024-5-9 17:18:39
    #include<iostream>
    #include<algorithm>
    using namespace std;
    int w[30],v[30],f[50000];
    int n,m;
    int main()
    {
        cin>>m>>n;
        for(int i=1;i<=n;i++)
        {
            cin>>v[i]>>w[i];
            w[i]*=v[i];
        }
        for(int i=1;i<=n;i++)
        {
            for(int j=m;j>=v[i];j--)
            {
                if(j>=v[i])
                {
                    f[j]=max(f[j],f[j-v[i]]+w[i]);
                }
            }
        }
        cout<<f[m]<<endl;
        return 0;
    }
    

    已AC

    • 1

    [NOIP2006 普及组] 开心的金明

    信息

    ID
    887
    时间
    1000ms
    内存
    128MiB
    难度
    2
    标签
    递交数
    37
    已通过
    24
    上传者