参考代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int n,m;
int a[10005];
bool vis[12005];
int cnt[100005];
int main()
{
while(cin>>n&&n!=0)
{
memset(vis,0,sizeof(vis));
for(int i=0;i<n;i++)
{
cin>>a[i];
}
sort(a,a+n);
cin>>m;
int ans=1;
cnt[0]=0;
int maxz=0;
for(int i=0;i<n;i++)
{
int temp=ans;
for(int j=0;j<temp;j++)
{
int v=cnt[j]+a[i];
if(cnt[j]<=m&&!vis[v])
{
cnt[ans++]=v;//
vis[v]=1;
maxz=max(maxz,v);
}
}
}
cout<<m-maxz<<endl;
}
}
0.0分
2 人评分
【亲和数】 (C语言代码)浏览:492 |
分糖果 (C++代码)浏览:1438 |
C语言训练-大、小写问题 (C语言代码)浏览:724 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:598 |
DNA (C语言描述,蓝桥杯)浏览:1553 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:780 |
母牛的故事 (C语言代码)浏览:715 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:504 |
杨辉三角 (C语言代码)浏览:484 |
2^k进制数 (C语言描述,蓝桥杯)浏览:1419 |