1244. Gentlemen

系统 1573 0

http://acm.timus.ru/problem.aspx?space=1&num=1244

背包题  理解并不难

主要在于如果答案有多个要输出 -1

一个答案的话要输出结果   否则输出 0

用 sum [ n ] 表示到 n 有几条路径

状态转移方程为 

if(sum[j-a[i]])//a[i]表示第i个数据的大小

{
        sum[j]=max(sum[j]+1,sum[j-a[i]]);

}

代码及其注释:

      #include <iostream>

#include <cstdio>

#include <cstring>

#include <algorithm>



#define LL long long



using namespace std;



const int N=100003;

int sum[N];//到 N 有几条路径

int f[N];// 记录第一次到此用了那个数据

int a[103];// 数据大小

bool select[103];//是否用了

void Fselect(int x)//记录用了哪几个数据

{

    while(x)

    {

        select[f[x]]=true;

        x=x-a[f[x]];

    }

}

int main()

{

    //freopen("data.txt","r",stdin);

    int K,n;

    while(scanf("%d %d",&K,&n)!=EOF)

    {

        memset(sum,0,sizeof(sum));

        sum[0]=1;

        memset(select,false,sizeof(select));

        int m=0;

        for(int i=1;i<=n;++i)

        {

            scanf("%d",&a[i]);

            if(sum[K]>1)//如果答案有多个 则无需再找

            continue;

            m=min(m+a[i],K);//最大

            for(int j=m;j>=a[i];--j)

            {

                if(sum[j]==0)//如果是求得第一条到此路径 记录用了哪一数据

                {

                    f[j]=i;

                }

                if(sum[j-a[i]])//更新到此路径数目

                {

                   sum[j]=max(sum[j]+1,sum[j-a[i]]);

                }

            }

            if(sum[K]==1)

            Fselect(K);

        }

        if(sum[K]==0)

        {printf("0\n");continue;}

        if(sum[K]>1)

        {printf("-1\n");continue;}

        for(int i=1;i<=n;++i)

        {

            if(!select[i])

            printf("%d ",i);

        }

        printf("\n");

    }

    return 0;

}


    

 

1244. Gentlemen


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论