luogu 1094

贪心。

先按纪念品的价格排序一遍。

考虑最小的一个纪念品:如果可以和最大的纪念品合成一组,就合成一组。否则就让最大的纪念品单独一组。

#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;
}

 

posted @ 2018-01-24 12:07  TrassBlose  阅读(120)  评论(0编辑  收藏  举报