#include#include

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

1244. Gentlemen

系統 1916 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條評論
主站蜘蛛池模板: 亚洲精彩视频在线观看 | 色姑娘综合 | 欧美日韩视频在线播放 | 青草免费视频 | 亚洲啪啪免费视频 | 国产99视频在线观看 | 免费国产小视频在线观看 | 99re66热这里只有精品首页 | 久草在线视频在线观看 | 色噜噜视频 | 色婷婷综合激情 | 亚洲精品国产成人专区 | 亚洲欧美日韩高清中文在线 | 久热影视| 欧洲午夜视频 | 国产午夜在线观看 | 欧美日韩亚洲国产一区二区综合 | 国产精品 视频一区 二区三区 | 亚洲精品国产啊女成拍色拍 | 宅男噜噜噜66一区二区 | 久久成人动漫 | 日韩一区二区在线观看 | 中文线码中文高清播放中 | 中文字幕1区 | 夜夜夜夜夜操 | 国产中文字幕免费观看 | 欧美在线操| 91亚洲免费视频 | 成人在线视频观看 | 亚洲国产精久久久久久久春色 | 97最新| 免费性视频 | 亚洲国产精品一区二区久 | 日韩欧美亚洲综合一区二区 | 国产不卡免费 | 四虎影视永久免费视频观看 | 四虎影视在线 | 日韩欧美综合在线二区三区 | 乱色 另类图区 | 国产一级在线免费观看 | 日本高清不卡免费 |