[USACO 2010 Feb S]Chocolate Eating

简介: [USACO 2010 Feb S]Chocolate Eating

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

题目描述是复制的,可能有部分显示不对,我就把题目链接放下面!

题目链接: [USACO 2010 Feb S]Chocolate Eating

题目描述

输入描述

  • 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的代码吧:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,d;
ll a[100000];
ll l,r;
ll ans[100000];
int check(ll x){
    ll sum=0,ct=0;
    for(int i=1;i<=d;i++){//有个坑点就是: 最后一天不能剩巧克力
        while(sum<x){
            sum+=a[++ct];
            if(ct>n) return 0;
            if(x==l) ans[ct]=i;
        }
        sum>>=1;
    }
    return 1;
}
int main(){
    ios::sync_with_stdio(false);
    cin>>n>>d;
    ll sum=0;
    for(int i=1;i<=n;i++) cin>>a[i],sum+=a[i];
    l=0,r=sum;
    while(l<r){//二分模板
        ll mid=(l+r+1)>>1;
        if(check(mid)) l=mid;
        else r=mid-1;
    }
    cout<<l<<"\n";
    check(l);//这里调用是为了输出巧克力是第几天吃的
    for(int i=1;i<=n;i++)
        if(ans[i])cout<<ans[i]<<"\n";
        else cout<<d<<"\n";//输出剩余的巧克力
    return 0;
}


相关文章
|
7月前
USACO1.3 修理牛棚
USACO1.3 修理牛棚
[USACO 2021.02 Feb]Problem 1. Year of the Cow
[USACO 2021.02 Feb]Problem 1. Year of the Cow
[USACO 2021.02 Feb]Problem 3. Clockwise Fence
[USACO 2021.02 Feb]Problem 3. Clockwise Fence
|
算法
[USACO 2007 Jan S]Protecting the Flowers
[USACO 2007 Jan S]Protecting the Flowers
[USACO 2009 Dec S]Music Notes
[USACO 2009 Dec S]Music Notes
[USACO 2021.02 Feb]Problem 2. Comfortable Cows
[USACO 2021.02 Feb]Problem 2. Comfortable Cows
luogu CF776D The Door Problem(2-sat问题)
luogu CF776D The Door Problem(2-sat问题)
72 0
[USACO 2012 Feb B]Moo - 规律
题意: 某字符串由m o 两个字符构成 而且构成的字符串为前一个字符串 + m + o * (i+2) + 前一个字符串 *(i+2)指的是数量 问字符串第n个字符是什么 思路: 在从一个字符串构成下一个字符串的时候,是有一定的规律的,所以我们可以很轻松地找到规律 然后就可以递归地找,满足规律的时候直接输出
172 0
[USACO 2012 Feb B]Moo - 规律
[USACO 2012 Feb G]Cow Coupons----贪心&带悔(看完稳AC)
意思是有n头牛,现在有k张优惠券以及m元,每头牛有一个原始价格和折扣价格,问最多能买多少牛 一开始的方法很简单,由于题目里面说了折扣价格一定比原始价格便宜,所以说首先按照折扣价格从小大大进行排序,将前k个牛的花费看作是折扣之后的价格,而将后面的花费看作是原始价格,然后重新将价值从小到大进行排序,尽可能的多选
250 0
[USACO 2012 Feb G]Cow Coupons----贪心&带悔(看完稳AC)