上色的纱雾

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);}}

的时间进行二分查找

上色的纱雾(二分搜索)相关推荐

  1. sdut-3916 上色的纱雾

    题目链接:sdut-3916 上色的纱雾 题目解法: 二分搜索合适的答案,并不断往小了更新答案.因为往小了更新答案与向下搜索答案都需要bisearch(l, len),而 < m时更新答案不影响 ...

  2. SDUT 3916 上色的纱雾

    SDUT 3916 上色的纱雾 Time Limit: 1000MS Memory Limit: 65536KB Problem Description 纱雾画画功力首屈一指,现在她准备上色了,这时候 ...

  3. “师创杯”山东理工大学第九届ACM程序设计竞赛 热身赛 E.上色的纱雾【二分+贪心】

    上色的纱雾 Time Limit: 1000MS  Memory Limit: 65536KB Submit  Statistic Problem Description 纱雾画画功力首屈一指,现在她 ...

  4. 二次元和穿纱雾网站错误404源码

    介绍: 今天分享一款许多老二次元的朋友们都比较喜欢的老婆,和泉纱雾的404页面的网页源代码,进入这个404页面就能看到我们的女主角和泉纱雾,相当简约好看,所以和泉雾纱是我老婆. 安装教程: 1.下载源 ...

  5. 和泉纱雾——初级思维题

    Think: 1.观察规律可以发现,尽量满足位数优先,若位数一样则考虑可以选择的较大的数字,将其放于最高位 2.n值相对较大,建议直接输出结果 Problem Description 众所周知,和泉纱 ...

  6. SDUT-3880 和泉纱雾

    和泉纱雾 Time Limit: 1000MS Memory Limit: 65536KB Problem Description 众所周知,和泉纱雾是著名的埃罗芒阿老师,画画功力首屈一指.今天我们的 ...

  7. python ccbox_python--easygui

    1.msgbox import easygui as eg # msgbox # 一般使用三个参数,msg:内容,title:标题,ok_button:按钮内容 eg.msgbox(msg=" ...

  8. live2d内嵌html,为你的博客博客/网页添加Live2d二次元老婆的插件/手动方法

    前言 好久没搞WP的教程了,想不想为你的博客加一个看板娘呢,反正我想2333,所以我便汇总了一下网上这些教程模型和机器人api. 插件版 Wordpress 1.Wikimoe大佬制作的插件(伊斯特瓦 ...

  9. 行路难(SPFA+前驱记录)

    与其留恋,不如洒脱. -NEMT2018后的首题祭 行路难(SPFA+前驱记录) 题目来自洛谷P2832,难度(提高+/省选-),自以为应该是(普及/提高-)的黄题. 题目概述:给定一张有向图,在图上 ...

最新文章

  1. css3弹性盒子模型之box-flex
  2. 浅谈 JavaScriptCore
  3. [转]创建一个JavaScript弹出DIV窗口层的效果
  4. CentOS 快速安装pip
  5. 【牛客 - 303B第十五届浙江大学宁波理工学院程序设计大赛(同步赛)】Fibonacci and Counting(Fib数性质,gcd辗转相除法性质)
  6. 汇编中的函数调用与递归
  7. 如何成为一名优秀的高级C/C++程序员
  8. python如何使数据加行_如何使用 Python 插入行
  9. [转载] python全局变量的使用
  10. Java使用笔记之stream和sorted使用
  11. HDTunePro v5.00 硬盘专业工具(绿色版)
  12. iPhone系统关闭自动更新并去除设置上的红点
  13. 逆向系列之获取任意微信小程序code
  14. 郑州大学计算机课程表查询,郑州大学研究生课程表
  15. Pixhawk-姿态解算源码注释
  16. onenote标注pdf笔记_如何高效利用OneNote做笔记?
  17. java中倒出pdf增加高宽_java – 如何扩展PDF的页面大小以添加水印...
  18. 解密腾讯前端技术体系
  19. 基于python的Topsis(优劣解距离)算法的实现(附代码及举例说明)
  20. 本体李俊|区块链的实际业务场景需要哪些技术模块?

热门文章

  1. macOS中快速复制文件路径
  2. vue-echarts-v3——浙江省地图下钻(eg:浙江省-嘉兴市-嘉善县)
  3. QForkMasterInit: system error caught. error code=0x000005af, message=VirtualAllocEx ,redis出现闪退
  4. 大型网站技术架构学习
  5. request 和require区别_「猫咪词汇」语音讲解 suggest /advise /request/ require辨析
  6. 星云大师:这十句话 我受用一生
  7. 2021 年,Java 开发者最值得学习的 14 项技能
  8. bitcomet比特彗星教程(bt种子下载)
  9. 【PostgreSQL】存储过程
  10. 生成p12自签名数字证书使用p12证书为apk签名