上色的纱雾(二分搜索)
上色的纱雾
Time Limit: 1000 ms / Memory Limit: 65536 kb
Description
纱雾画画功力首屈一指,现在她准备上色了,这时候她在想,怎样上色的时间最短呢?
在这里我们把问题简化,平面图抽象成坐标轴,需要上色的地方抽象成 n 个点,纱雾有 m 支画笔。
开始的时候纱雾可以选择让画笔落在坐标轴任意一点上,之后每次移动画笔一个单位的距离都会花费 1 秒(画笔可以左右移动,纱雾强大的能力可以同时移动 m 枝画笔,涂色的时间忽略不计)。现在纱雾想要知道这 n 个点全部上完色最少要多少时间呢?
相信你一定能让可爱的纱雾露出这样的表情的:
Input
多组输入。
对于每组数据:
- 首先输入两个以空格分隔的整数 n, m (1 <= n, m <= 10^5),分别表示需要上色的点以及纱雾拥有的画笔的数量
- 接下来一行是 n 个以空格分隔的整数(绝对值保证不超过 10^9)
Output
对于每组数据,输出一个整数,表示纱雾需要的最少时间(秒)。
Sample Input
3 2 1 4 8 3 1 1 2 9 4 2 1 2 3 6
Sample Output
3 8 2
这个题一开始什么也想不到,就是想怎么把m个笔安排
但是其实思路应该是对需要
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m;
int a[100005];
long long ans=0;
void binserch(int low,int high)
{if(low>high)return;int mid=(high-low)/2+low;//mid为时间 代表了最大和最低时间的中间值int sum=0,counts=1;//sum是一个笔在mid时间下最多可以画几个点//ounts记录了需要几个笔for(int i=1;i<n;++i){if(sum+a[i]-a[i-1]<=mid)//如果该笔连这连个点的时间小于mid,意味着该笔可以在mid内连起这两个点{sum+=a[i]-a[i-1];}else//如果超出了mid那么意味着需要再加上一个笔{sum=0;counts++;}}if(counts>m)//如果笔数超出了提供的笔数,那么寻找更大的时间{binserch(mid+1,high);}else//如果满足条件 那么记录mid 并且继续寻找更小的时间可不可以{ans=mid;binserch(low,mid-1);}
}
int main(void)
{while(scanf("%d%d",&n,&m)!=EOF){int high,low;for(int i=0;i<n;++i){scanf("%d",&a[i]);}sort(a,a+n);low=0;high=a[n-1]-a[0];//low为需要的最少时间,high为需要的最大时间,也就是一个笔从头画到尾binserch(low,high);printf("%lld\n",ans);}}
的时间进行二分查找
上色的纱雾(二分搜索)相关推荐
- sdut-3916 上色的纱雾
题目链接:sdut-3916 上色的纱雾 题目解法: 二分搜索合适的答案,并不断往小了更新答案.因为往小了更新答案与向下搜索答案都需要bisearch(l, len),而 < m时更新答案不影响 ...
- SDUT 3916 上色的纱雾
SDUT 3916 上色的纱雾 Time Limit: 1000MS Memory Limit: 65536KB Problem Description 纱雾画画功力首屈一指,现在她准备上色了,这时候 ...
- “师创杯”山东理工大学第九届ACM程序设计竞赛 热身赛 E.上色的纱雾【二分+贪心】
上色的纱雾 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 纱雾画画功力首屈一指,现在她 ...
- 二次元和穿纱雾网站错误404源码
介绍: 今天分享一款许多老二次元的朋友们都比较喜欢的老婆,和泉纱雾的404页面的网页源代码,进入这个404页面就能看到我们的女主角和泉纱雾,相当简约好看,所以和泉雾纱是我老婆. 安装教程: 1.下载源 ...
- 和泉纱雾——初级思维题
Think: 1.观察规律可以发现,尽量满足位数优先,若位数一样则考虑可以选择的较大的数字,将其放于最高位 2.n值相对较大,建议直接输出结果 Problem Description 众所周知,和泉纱 ...
- SDUT-3880 和泉纱雾
和泉纱雾 Time Limit: 1000MS Memory Limit: 65536KB Problem Description 众所周知,和泉纱雾是著名的埃罗芒阿老师,画画功力首屈一指.今天我们的 ...
- python ccbox_python--easygui
1.msgbox import easygui as eg # msgbox # 一般使用三个参数,msg:内容,title:标题,ok_button:按钮内容 eg.msgbox(msg=" ...
- live2d内嵌html,为你的博客博客/网页添加Live2d二次元老婆的插件/手动方法
前言 好久没搞WP的教程了,想不想为你的博客加一个看板娘呢,反正我想2333,所以我便汇总了一下网上这些教程模型和机器人api. 插件版 Wordpress 1.Wikimoe大佬制作的插件(伊斯特瓦 ...
- 行路难(SPFA+前驱记录)
与其留恋,不如洒脱. -NEMT2018后的首题祭 行路难(SPFA+前驱记录) 题目来自洛谷P2832,难度(提高+/省选-),自以为应该是(普及/提高-)的黄题. 题目概述:给定一张有向图,在图上 ...
最新文章
- css3弹性盒子模型之box-flex
- 浅谈 JavaScriptCore
- [转]创建一个JavaScript弹出DIV窗口层的效果
- CentOS 快速安装pip
- 【牛客 - 303B第十五届浙江大学宁波理工学院程序设计大赛(同步赛)】Fibonacci and Counting(Fib数性质,gcd辗转相除法性质)
- 汇编中的函数调用与递归
- 如何成为一名优秀的高级C/C++程序员
- python如何使数据加行_如何使用 Python 插入行
- [转载] python全局变量的使用
- Java使用笔记之stream和sorted使用
- HDTunePro v5.00 硬盘专业工具(绿色版)
- iPhone系统关闭自动更新并去除设置上的红点
- 逆向系列之获取任意微信小程序code
- 郑州大学计算机课程表查询,郑州大学研究生课程表
- Pixhawk-姿态解算源码注释
- onenote标注pdf笔记_如何高效利用OneNote做笔记?
- java中倒出pdf增加高宽_java – 如何扩展PDF的页面大小以添加水印...
- 解密腾讯前端技术体系
- 基于python的Topsis(优劣解距离)算法的实现(附代码及举例说明)
- 本体李俊|区块链的实际业务场景需要哪些技术模块?
热门文章
- macOS中快速复制文件路径
- vue-echarts-v3——浙江省地图下钻(eg:浙江省-嘉兴市-嘉善县)
- QForkMasterInit: system error caught. error code=0x000005af, message=VirtualAllocEx ,redis出现闪退
- 大型网站技术架构学习
- request 和require区别_「猫咪词汇」语音讲解 suggest /advise /request/ require辨析
- 星云大师:这十句话 我受用一生
- 2021 年,Java 开发者最值得学习的 14 项技能
- bitcomet比特彗星教程(bt种子下载)
- 【PostgreSQL】存储过程
- 生成p12自签名数字证书使用p12证书为apk签名