tyvj 1359 收入计划 二分
来源:互联网 发布:ps4模拟windows 编辑:程序博客网 时间:2024/05/16 12:15
题目描述:
描述
高考结束后,同学们大都找到了一份临时工作,渴望挣得一些零用钱。从今天起,Matrix67将连续工作N天(1<=N<=100 000)。每一天末他可以领取当天及前面若干天里没有领取的工资,但他总共只有M(1<=M<=N)次领取工资的机会。Matrix67已经知道了在接下来的这N天里每一天他可以赚多少钱。为了避免自己滥用零花钱,他希望知道如何安排领取工资的时间才能使得领到工资最多的那一次工资数额最小。注意Matrix67必须恰好领工资M次,且需要将所有的工资全部领走(即最后一天末需要领一次工资)。
输入格式
第一行输入两个用空格隔开的正整数N和M
以下N行每行一个不超过10000正整数,依次表示每一天的薪水。
以下N行每行一个不超过10000正整数,依次表示每一天的薪水。
输出格式
输出领取到的工资的最大值最小是多少。
测试样例1
输入
7 5
100
400
300
100
500
101
400
输出
500
备注
【样例说明】
采取下面的方案可以使每次领到的工资不会多于500。这个答案不能再少了。
100 400 300 100 500 101 400 每一天的薪水
<------1 <-------2 <---3 <---4 <---5 领取工资的时间
500 400 500 101 400 领取到的工资
采取下面的方案可以使每次领到的工资不会多于500。这个答案不能再少了。
100 400 300 100 500 101 400 每一天的薪水
<------1 <-------2 <---3 <---4 <---5 领取工资的时间
500 400 500 101 400 领取到的工资
代码:
#include<iostream>#include<cstdio>using namespace std;int n,m;int a[100000]={0};bool judge(int x){int s=0,y=1;for(int i=1;i<=n;i++){if(x<a[i]) return false;if(s+a[i]>x){y++;s=0;}s+=a[i];}if(y>m) return false;return true;}int main(){scanf("%d%d",&n,&m);int s=0;for(int i=1;i<=n;i++){scanf("%d",&a[i]);s+=a[i];}int l=s/m,r=s,mid;while(l+1<r){mid=(l+r)/2;if(judge(mid)){r=mid;}else{l=mid;}}printf("%d",r);return 0;}
2 0
- tyvj 1359 收入计划 二分
- [Tyvj 1359] 收入计划 · 二分答案
- 【二分答案】收入计划
- 【t035】收入计划
- Tyvj 1599 锻炼计划
- TYVJ P1463 智商问题(二分)
- [Tyvj 2476]贝茜的晨练计划
- tyvj 2075 差分数组+二分
- |Tyvj|二分|P1938 [Clover4]最优战舰
- TYVJ 1340 折半暴搜+二分
- 收入~~
- 收入
- TYVJ
- 【运输计划】【二分】【树上倍增】
- 健身计划(二分答案)
- [二分][并查集]周末出游计划
- 月球美容计划之二分哈希
- POJ训练计划2503_Babelfish(二分)
- HTCVive VR开发场景事件交互指南
- bzoj1051:受欢迎的牛(tarjan)
- 1013. Battle Over Cities
- Binder机制
- 欢迎使用CSDN-markdown编辑器
- tyvj 1359 收入计划 二分
- UVA 679 Dropping Balls (二叉树的编号)
- iOS NSThread NSOperation GCD的优缺点
- 关于hibernate级联的一点总结
- wsdl详解
- Java类初始化实验
- 1180
- 自调用匿名函数的2种写法
- C++输出单双精度数的小数点位数(如输出显示5.2365987456这样的数)