洛谷-P1094 纪念品分组

题目链接

思路:

(原谅我第一眼把题目看成纪念品龙狙hhh)
读入之后先用sort排序,然后用两个指针一起向中间走,每次选择都尽可能的让当前状态下最大的和最小的分在一组,如果不行就最大的单独分一组,这样贪心下来就是最少分的组了。

代码:

#include
#define int long long
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
const int N=2e5+5;
const int M=2e4+5;
const double eps=1e-8;
const int mod=1e9+7;
const int inf=0x7fffffff;
const double pi=3.1415926;
using namespace std;
int a[30001];
signed main()
{
    IOS;
    int W,n,ans=0;
    cin>>W>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
    }
    sort(a+1,a+n+1);
    int l=1,r=n;
    while(l<=r)
    {
        if(a[l]+a[r]<=W)
        {
            l++;
            r--;
            ans++;
        }
        else
        {
            r--;
            ans++;
        }
    }
    cout<<ans<<endl;
    return 0;
}

你可能感兴趣的:(思维,贪心)