华华给月月准备礼物题解

华华给月月准备礼物

http://www.nowcoder.com/questionTerminal/9963334321e64e61a397b262708e4f65

题意很简单,就是找把根木头砍出最长长度,而且每段长度都一样,所有一样的木头加起来>=K;
那么我们可以直接枚举你所需要长度对于每个原木头的贡献,然后,这个枚举长度就是二分答案去找,就是logn,然后算贡献就是N,所以直接搞他啊。

#include <bits/stdc++.h>
#define fio ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define debug(x) cout << #x << ": " << x << endl;
#define debug1(x) cout<<"xxx"<<endl;
#define ll long long
#define ull unsigned long long
#pragma GCC optimize("Ofast","inline","-ffast-math")
#pragma GCC target("avx,sse2,sse3,sse4,mmx")
#define mse(a,b) memset(a,b,sizeof b);
using namespace std;
const int maxx=1e6+100;
const int mod=1e9+7;
ll ans[maxx];
int main()
{
    fio;
   ll n,k;
   cin>>n>>k;
   for(int i=0;i<n;i++)
    cin>>ans[i];
    ll l=0,r=1e9;
    ll dou;
   while(l<=r)
   {

       ll sum=0;
       ll mid=(l+r)>>1;
       for(int i=0;i<n;i++)
       {
           sum+=ans[i]/mid;
       }
       if(sum<k)
       {
           r=mid-1;
       }
       else
       {
           dou=mid;
           l=mid+1;
       }
   }
   cout<<dou<<endl;
    return 0;
}
全部评论

相关推荐

11-08 16:53
门头沟学院 C++
投票
滑模小马达:第三个如果是qfqc感觉还行,我签的qfkj搞电机的,违约金也很高,但公司感觉还可以,听说之前开过一个试用转正的应届生,仅供参考。
点赞 评论 收藏
分享
10-14 13:25
已编辑
门头沟学院 C++
点赞 评论 收藏
分享
最近和朋友聊天,她说了句让我震惊的话:"我发现我连周末点外卖都开始'最优解'了,一定要赶在高峰期前下单,不然就觉得自己亏了。"这不就是典型的"班味入侵"吗?工作思维已经渗透到生活的方方面面。
小型域名服务器:啊?我一直都这样啊?我还以为是我爱贪小便宜呢?每次去实验室都得接一杯免费的开水回去,出门都得规划一下最短路径,在宿舍就吃南边的食堂,在实验室就吃北边的食堂,快递只有顺路的时候才取。
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务