贪心。
先按纪念品的价格排序一遍。
考虑最小的一个纪念品:如果可以和最大的纪念品合成一组,就合成一组。否则就让最大的纪念品单独一组。
#include"cstdio" #include"cctype" #include"algorithm" using namespace std; int read() { int c,x=0; while(!isdigit(c=getchar())); while(x=x*10+c-‘0‘,isdigit(c=getchar())); return x; } int a[30001]; int main() { int w=read(),n=read(),tot=0; for(int i=1; i<=n; i++) a[i]=read(); sort(a+1,a+n+1); int l=1,r=n; while(l<=r) if(a[l]+a[r]<=w) l++,r--,tot++; else r--,tot++; printf("%d",tot); return 0; }