[USACO 2010 Feb S]Chocolate Eating

£神魔★判官ぃ 2024-04-20 07:15 138阅读 0赞

简单说两句

作者:**后端小知识**

CSDN个人主页:后端小知识

?GZH后端小知识

?欢迎关注?点赞?收藏⭐️留言?

题目: [USACO 2010 Feb S]Chocolate Eating ,哈哈,我们今天来看一道二分答案的题嘛,这是选自USACO上的一道题,好了,我们一起来看看题意吧:

题目描述是复制的,可能有部分显示不对,我就把题目链接放下面!
题目链接: [USACO 2010 Feb S]Chocolate Eating

题目描述

watermark_type_d3F5LXplbmhlaQ_shadow_50_text_Q1NETiBAY3EudGlhbmN4_size_20_color_FFFFFF_t_70_g_se_x_16

输入描述

  • Line 1: Two space separated integers: N and D
  • Lines 2…N+1: Line i+1 contains a single integer: Hi

输出描述

  • Line 1: A single integer, the highest Bessie’s minimum happiness can be over the next D days
  • Lines 2…N+1: Line i+1 contains an integer that is the day on which Bessie eats chocolate i

示例1

输入

5 5
10
40
13
22
7

输出

24
1
1
3
4
5

思路:

这道题我们直接用二分答案的思想来解决,二分最小快乐值,若当天的快乐值达不到,则吃巧克力,若巧克力不够,则当前这个答案大了,不符合题意!具体的看代码,有注释!

我们来看看成功AC的代码吧:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. typedef long long ll;
  4. ll n,d;
  5. ll a[100000];
  6. ll l,r;
  7. ll ans[100000];
  8. int check(ll x){
  9. ll sum=0,ct=0;
  10. for(int i=1;i<=d;i++){
  11. //有个坑点就是: 最后一天不能剩巧克力
  12. while(sum<x){
  13. sum+=a[++ct];
  14. if(ct>n) return 0;
  15. if(x==l) ans[ct]=i;
  16. }
  17. sum>>=1;
  18. }
  19. return 1;
  20. }
  21. int main(){
  22. ios::sync_with_stdio(false);
  23. cin>>n>>d;
  24. ll sum=0;
  25. for(int i=1;i<=n;i++) cin>>a[i],sum+=a[i];
  26. l=0,r=sum;
  27. while(l<r){
  28. //二分模板
  29. ll mid=(l+r+1)>>1;
  30. if(check(mid)) l=mid;
  31. else r=mid-1;
  32. }
  33. cout<<l<<"\n";
  34. check(l);//这里调用是为了输出巧克力是第几天吃的
  35. for(int i=1;i<=n;i++)
  36. if(ans[i])cout<<ans[i]<<"\n";
  37. else cout<<d<<"\n";//输出剩余的巧克力
  38. return 0;
  39. }

【都看到这了,点点赞点点关注呗,爱你们】??

抽象工厂  引导关注

结语

谢谢你的阅读,由于作者水平有限,难免有不足之处,若读者发现问题,还请批评,在留言区留言或者私信告知,我一定会尽快修改的。若各位大佬有什么好的解法,或者有意义的解法都可以在评论区展示额,万分谢谢。
写作不易,望各位老板点点赞,加个关注!???

?

作者:**后端小知识**

CSDN个人主页:后端小知识

?GZH后端小知识

?欢迎关注?点赞?收藏⭐️留言?

发表评论

表情:
评论列表 (有 0 条评论,138人围观)

还没有评论,来说两句吧...

相关阅读