【洛谷P2409】Y的积木

这是一道dp……

f [ i ] [ j ] 表示前 i 组,总和为 j 时的方案数

f [ i ] [ j + a [ i ] [ k ] ] <-- f [ i - 1 ] [ j ]

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<algorithm> 
 4 using namespace std;
 5 const int N=105,M=11000;
 6 int f[N][M],a[N][N],maxl[N],maxn,n,Q;
 7 int main(){
 8     maxn=0;
 9     scanf("%d %d",&n,&Q);
10     for (int i=1;i<=n;i++){
11         scanf("%d",&a[i][0]);
12         for (int j=1;j<=a[i][0];j++){
13             scanf("%d",&a[i][j]);
14             if (a[i][j]>maxl[i])
15                 maxl[i]=a[i][j];
16         }
17         maxn+=maxl[i];
18         sort(a[i]+1,a[i]+a[i][0]+1);
19     }
20     for (int i=1;i<=a[1][0];i++)
21         f[1][a[1][i]]++;//初始化不能赋成1 
22     for (int i=2;i<=n;i++)
23         for (int j=1;j<=maxn;j++){
24             if (!f[i-1][j])
25                 continue;
26             for (int k=1;k<=a[i][0];k++)
27                 f[i][j+a[i][k]]+=f[i-1][j];
28         }
29     int p=1,j=0;
30     while (p<=Q){
31         j++;
32         for (int i=1;i<=f[n][j];i++){
33             if (p>Q) return 0;
34             printf("%d ",j);
35             p++;
36         }
37     }
38     return 0;
39 }
STD

 

转载于:https://www.cnblogs.com/Absolute-Zero/p/6012600.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值