二分算法的应用——Codevs 1766 装果子
#include<iostream>
#include<cstdio>
using namespace std; const int maxn = + ;
typedef long long LL; LL a[maxn], v, n, m, max_R, max_L; //max_R是上界, max_l是下界 bool C(LL v) //当前袋子体积 v
{
LL cnt = , now = ;
for(int i = ;i <= n;i ++)
{
if(now + a[i] <= v) //当前未装满的袋子,尝试是否装下这个树下的苹果,
{ //当前袋子已经装的体积+当前树下苹果体积<=v,就装苹果
now += a[i];
}
else //否则, 用新袋子
{
if(a[i] > v) { //当前树下苹果大于袋子v,就所有袋子都不能装了,直接当前的v,不成立了
return false;
}
cnt ++; //袋子数++
now = a[i]; //用了新袋子, 然后新袋子装了当前树的所有苹果的v if(cnt > m) { //如果 袋子数 > m
return false;
}
}
}
return true;
} void solve()
{
cin >> n >> m;
for(int i = ;i <= n;i ++)
{
cin >> a[i];
max_R += a[i];
max_L = max(max_L, a[i]);
} LL l = max_L - , r = max_R + ;
while(r - l > )
{
LL mid = (l + r) / ;
if(C(mid)) { //满足,就缩小上界(v)
r = mid;
}
else { //不满足,就提高下界(v)
l = mid;
}
}
cout << r << endl;
} int main()
{
solve(); return ;
}
二分算法的应用——Codevs 1766 装果子的更多相关文章
- codevs 1766 装果子
		提交地址:http://codevs.cn/problem/1766/ 1766 装果子 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题目描述 De ... 
- python-Day4-迭代器-yield异步处理--装饰器--斐波那契--递归--二分算法--二维数组旋转90度--正则表达式
		本节大纲 迭代器&生成器 装饰器 基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ... 
- what' the python之递归函数、二分算法与汉诺塔游戏
		what's the 递归? 递归函数的定义:在函数里可以再调用函数,如果这个调用的函数是函数本身,那么就形成了一个递归函数. 递归的最大深度为997,这个是程序强制定义的,997完全可以满足一般情况 ... 
- Python练习-递归二分算法
		# 编辑者:闫龙 #递归,二分算法演示 l = [i for i in range(1,100)]#定义一个列表l,并追加1-99的所有数字 def FindNum(num,l):#定义函数FindN ... 
- Java冒泡,快速,插入,选择排序^_^+二分算法查找
		这段时间在学Java,期间学到了一些排序和查找方法.特此写来和大家交流,也方便自己的日后查看与复习. 1.下边是Java的主类: public class Get { public static vo ... 
- #AcWing系列课程Level-2笔记——4. 浮点数二分算法
		浮点数二分算法 编写浮点数二分,记住下面的思路,代码也就游刃有余了! 1.首先找到数组的中间值,mid=(left+right)>>1,区间[left, right]被划分成[left, ... 
- #AcWing系列课程Level-2笔记——3. 整数二分算法
		整数二分算法 编写整数二分,记住下面的思路,代码也就游刃有余了! 1.首先找到数组的中间值,mid=(left+right)>>1,区间[left, right]被划分成[left, mi ... 
- java 的二分算法
		二分算法 就是在 一组 有序 数组中 通过中间值(数组中间的那个数字)的方法 找到 某个数的下标,如果大于中间值 ,则在中间值与最大值之间 的中间值再比较. public class two { // ... 
- 算法leetcode二分算法
		二分算法通常用于有序序列中查找元素: 有序序列中是否存在满足某条件的元素: 有序序列中第一个满足某条件的元素的位置: 有序序列中最后一个满足某条件的元素的位置. 思路很简单,细节是魔鬼. 一.有序序列 ... 
随机推荐
- 在onResume()中调用getIntent()得不到Extra的问题
			之前 想做activity间的传值,注意 不是 startActivityforResult的那种, 在启动了多层activity再次启动activity想进入到singleTask的MainActi ... 
- Redis&PHP的使用安装-windows版
			Redis是一个Key-value的数据结构存储系统,可以以数据库的形式,缓存系统,消息处理器使用,它支持的存储value类型很多,例如,string.list(链表).set(集合).zset(so ... 
- [转帖] InfiniBand主流厂商和产品分析
			https://blog.csdn.net/swingwang/article/details/72935461 InfiniBand主流厂商和产品分析 2017年06月08日 22:03:46 Ha ... 
- Java多线程(五) —— 线程并发库之锁机制
			参考文献: http://www.blogjava.net/xylz/archive/2010/07/08/325587.html 一.Lock与ReentrantLock 前面的章节主要谈谈原子操作 ... 
- oracle表空间到32G后扩容
			), ) total_space FROM dba_data_files ORDER BY tablespace_name; /*查看表空间的使用情况*/ select a.a1 表空间名称, tru ... 
- GIT的使用方法
			GIT的使用方法 1.电脑首先安装GIT, 2.在官网注册GitHub账号. 一,使用git在控制台进行本地操作 1.打开GitBash 2.填写用户名和邮箱作为标识分别执行以下命令: git/ co ... 
- python的==和is区别
			Python中: is判断两个标识符是否引自同一个对象 ==判断两个标识符的值是否相等 区别于java: ==判断两个标识符是否引自同一个对象 .equals()判断是否相等 #如果是String ... 
- mysql测试索引在表中的作用
			//未完成 参考书:(完成对缓存中执行计划的查看对比 P133~) Microsoft SQL Server 2008技术内幕:T-SQL查询 实验内容 单表中的索引使用 1.建表 create ta ... 
- Lattice Point or Not UVA - 11768(拓展欧几里得)
			原文地址:https://www.cnblogs.com/zyb993963526/p/6783532.html 题意: 给定两个点A(x1,y1)和B(x2,y2),均为0.1的整数倍.统计选段AB ... 
- 【刷题】洛谷 P3834 【模板】可持久化线段树 1(主席树)
			题目背景 这是个非常经典的主席树入门题--静态区间第K小 数据已经过加强,请使用主席树.同时请注意常数优化 题目描述 如题,给定N个正整数构成的序列,将对于指定的闭区间查询其区间内的第K小值. 输入输 ... 
