纪念品分组

纪念品分组

https://ac.nowcoder.com/acm/problem/16640

先排序,用双指针扫描
定义 L 为左指针,R 为右指针,总组数sum=0,每次相加左右指针指向的元素,若大于价格上限则R--,sum++;
否则两指针同时往中间移一位即L++,R--;
如果L==R,说明只剩下一个数了,总组数sum++,如果L>R,就结束了。
代码

#include<bits/stdc++.h>
using namespace std;
int main()
{
    int w,n,sum=0;
    cin>>w>>n;
    int a[n];
    for(int i=0;i<n;i++) cin>>a[i];
    sort(a,a+n);
    int l=0,r=n-1;
    while(l<=r)
    {
        while(a[l]+a[r]>w&&l<r) sum++,r--;//如果大于就右指针向左移
        l++;
        r--;
        sum++;//小于等于的话就让l++,r--,总组数+1
    }
    cout<<sum;
    return 0;
}
全部评论

相关推荐

代码飞升AL:同学院本建议你换一个项目 就算你不去特意搜也应该知道点评不能写吧 保持投递不要停 然后快速弄一个项目换上去 公司就别挑了 我第一段120一天 快速跳就行
点赞 评论 收藏
分享
04-15 09:59
门头沟学院 C++
yy_11:小公司人家没必要泄密,大公司都是本地部署了
你想吐槽公司的哪些规定
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务