博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷 P3853 路标设置 解题报告
阅读量:5346 次
发布时间:2019-06-15

本文共 1012 字,大约阅读时间需要 3 分钟。

P3853 路标设置

题目背景

B市和T市之间有一条长长的高速公路,这条公路的某些地方设有路标,但是大家都感觉路标设得太少了,相邻两个路标之间往往隔着相当长的一段距离。为了便于研究这个问题,我们把公路上相邻路标的最大距离定义为该公路的“空旷指数”。

题目描述

现在政府决定在公路上增设一些路标,使得公路的“空旷指数”最小。他们请求你设计一个程序计算能达到的最小值是多少。请注意,公路的起点和终点保证已设有路标,公路的长度为整数,并且原有路标和新设路标都必须距起点整数个单位距离。

输入输出格式

输入格式:

第1行包括三个数L、N、K,分别表示公路的长度,原有路标的数量,以及最多可增设的路标数量。

第2行包括递增排列的N个整数,分别表示原有的N个路标的位置。路标的位置用距起点的距离表示,且一定位于区间[0,L]内。

输出格式:

输出1行,包含一个整数,表示增设路标后能达到的最小“空旷指数”值。


最开始想错了

贪心:每次取最大区间插中点。


正解:二分答案,check时加点

CODE:

#include 
#include
#define mid (l+r>>1)using namespace std;const int N=100010;int L,n,k,a[N];bool check(int d){ int last=0,cnt=k; for(int i=1;i<=n;i++) { while(a[i]>last+d) { cnt--; last+=d; } last=a[i]; if(cnt<0) return false; } return true;}int main(){ scanf("%d%d%d",&L,&n,&k); for(int i=1;i<=n;i++) scanf("%d",a+i); sort(a+1,a+1+n); a[++n]=L; int l=1,r=L; while(l

2018.5.5

转载于:https://www.cnblogs.com/butterflydew/p/8999731.html

你可能感兴趣的文章
十一、类型转换
查看>>
面试内容,值得一看
查看>>
UILabel
查看>>
【热门技术】三种SEO方式
查看>>
[Hades_技术]哈迪斯初级技术应用
查看>>
SQLiteOpenHelper
查看>>
Luogu P1141 01迷宫【搜索/dfs】By cellur925
查看>>
js onclick事件传参
查看>>
WiCloud 商业Wi-Fi管理平台
查看>>
团队项目--未完待续
查看>>
双重标准,我该怎么解决
查看>>
python中的网页标签等字符处理
查看>>
Mybatis输入类型和结果类型
查看>>
Linux常用命令(五)
查看>>
Linux常用命令(四)
查看>>
Linux常用命令(六)
查看>>
Linux常用命令(六)
查看>>
Linux常用命令(八)
查看>>
Linux常用命令(七)
查看>>
Linux常用命令(九)
查看>>