华华给月月准备礼物题解

华华给月月准备礼物

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;
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-27 18:00
点赞 评论 收藏
分享
认真搞学习:28小登的建议,投算法岗不要写什么物理竞赛,互联网+,多写点项目,用什么算法做了什么。还有本科算法是不可能的开发你这个也没有项目啊
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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