牛客多校第六场 D

图片说明
图片说明

  • 题意:
  • 就是个背包的题意,有n个物体和k个背包,输出最小的背包体积装下所有的物体,
  • 不过装物体有个定义,要求先从大的装,直到装不下为止。
  • 题解:
  • 二分能做,但是这题二分没有唯一解啊!
  • 题解这么说的:
  • 15 5
  • 39 39 39 39 39 60 60 60 60 60 100 100 100 100 100
  • 199 为一个合法的答案,但 200 不是,201 也不是
  • 二分找最优解没法做
  • 但是可以二分找局部解,然后枚举就行了。
  • 这里我看了大佬的代码,也是过了,multiset果然好用啊,赶紧记一下。
  • 代码:
    #include <bits/stdc++.h>
    using namespace std;
    #define ll long long
    int n,k;
    int a[1010];
    int solve(int x)
    {
      int cnt = 0;
      multiset<int> s(a,a+n);
      multiset<int>::iterator it;
      while(1)
      {
          if(++cnt > k)
              return 0;
          int rem = x;
          while(s.size() && rem >= *s.begin())
          {
              it = prev(s.upper_bound(rem));
              //cout<<s.size()<<" "<<*it<<endl;
              rem -= *it;
              s.erase(it);
          }
          if(s.empty())
              return 1;
      }
    }
    int main()
    {
      int t,cas = 0;
      cin>>t;
      while(t--)
      {
          int maxx = 0,sum = 0;
          cin>>n>>k;
          for(int i=0;i<n;i++)
          {
              cin>>a[i];
              if(a[i] > maxx)
                  maxx = a[i];
              sum += a[i];
          }
          maxx = max(maxx,sum/k);
          while(!solve(maxx)){
              maxx++;
          }
          printf("Case #%d: %d\n",++cas,maxx);
      }
      return 0;
    }
    

```

全部评论

相关推荐

2025年10月3日中午,在写完定时一年后发给自己的信之后,敲下键盘,写下这篇文字。我把标题的“所有人”加了引号,因为如我们所见,确实有的人顺风顺水,每天过的很开心,或是早早进入大厂,或是年纪轻轻就拿到了高薪offer,或是过着可能我努力十年也不一定实现的生活。但也许,不是每个人的痛苦都能被别人看到的,这个月我经常会哭,被骗6000块钱、手上钱不够导致拖欠房租、生活还要借朋友钱、国庆长假也没有钱去旅游,互联网公司不稳定担心试用期不过(毕竟上段实习就是被裁了,一有点风吹草动就害怕),但这样的我,不是所有人都知道的,居然是有些朋友的羡慕对象。回忆我的七年“长跑”别人都是多年幸福的恋爱长跑,我没有恋...
故事和酒66:让每一颗种子找到合适自己的生长方式,最终绽放出独一无二的花朵,这远比所有人都被迫长成同一棵“参天大树”的世界,更加美好和富有生机。这是社会和环境的问题,而不是我们的问题。然而就是在这样的环境中,楼主依然能突破自我,逆势成长,其中的艰辛可想而知。这一路的苦难终究会化作你成长的养料
你小时候最想从事什么职业
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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