| | | | 描述 Description | | | 有n种硬币,面值为别为a[1],a[2],a[3]……a[n],每种都有无限多。给定非负整数s,可以选取多少个硬币使得面值和恰好为s?输出硬币数目最小值和最大值 | | | |
| | | | 输入格式 Input Format | | | 第1行n 第2行s 第3到n+2行为n种不同的面值 | | | |
| | | | 输出格式 Output Format | | | 第1行为最小值 第2行为最大值 | | | |
| | | | 注释 Hint | | | 1<=n<=100 1<=s<=10000 1<=a[i]<=s | |
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int dp[11000];
int a[111];
int main()
{
int n;
while(scanf("%d",&n)==1)
{
int m;scanf("%d",&m);
for(int i=0;i<n;i++) scanf("%d",&a[i]);
//完全背包 恰好 最少
memset(dp,10,sizeof(dp));dp[0]=0;
for(int i=0;i<n;i++)
{
for(int j=a[i];j<=m;j++)
{
dp[j]=min(dp[j],dp[j-a[i]]+1);
}
}
int _min=dp[m];
//完全背包 恰好 最大
for(int i=1;i<=m;i++) dp[i]=-(1<<25);dp[0]=0;
for(int i=0;i<n;i++)
{
for(int j=a[i];j<=m;j++)
{
dp[j]=max(dp[j],dp[j-a[i]]+1);
}
}
int _max=dp[m];
printf("%d/n%d/n",_min,_max);
}
return 0;
}