【链接】 我是链接,点我呀:)

【题意】

长度为n的一个序列,其中有一些部分可能是空的,一些部分是长度为a的物品的一部分

(总共有k个长度为a的物品,一个放在位置i长度为a的物品会占据i,i+1,....i+a-1这a个格子

(物品之间必须要有至少一个空格,不能相邻

现在有一个人猜了m个不同的位置

你每次都说那个位置不是物品的一部分。(骗他)

那么请问最少在第几次你会露馅?(知道你在骗他)

【题解】

对于一个连续的空白的区间[l,r],设其长度为len=r-l+1
那么这个空白区间最多能放下(len+1)/(a+1)个物品
(注意每个物品之间至少要有一个空格,所以每个物品理论上占据了a+1个空间
(但是最后一个物品它最后面可以不用有空格,因此我们可以多给它一个"虚拟"空间,覆盖到这种情况
可以这样做,我们按顺序加入那个人猜的断点
将包含这个断点的区间(一开始只有[1,n+1),注意一定要用左闭右开区间,不然类似[x,x]这样的区间不好表示
分成[l,x-1]和[x+1,r]
并且减去[l,r]能放下的物品数
然后改为增加两个子区间能放下的物品数
直到能放下的物品数量小于k为止
(用一个一个的点来表示区间,注意这个区间里面的区间都是左闭右开区间)
(在分成两个子区间之后,我们会在集合中加入x和x+1,理论上我们还能通过查找x找到[x,x+1)这个区间,但是这个区间其实是不存在的了)
(插入的x仅仅是为了给[l,x)这个区间服务的,因为不会重复猜测所以没影响

【代码】

import java.io.*;
import java.util.*; public class Main { static InputReader in;
static PrintWriter out; public static void main(String[] args) throws IOException{
//InputStream ins = new FileInputStream("E:\\rush.txt");
InputStream ins = System.in;
in = new InputReader(ins);
out = new PrintWriter(System.out);
//code start from here
new Task().solve(in, out);
out.close();
} static int N = 50000;
static class Task{
int n,k,a;
int m;
TreeSet myset = new TreeSet(); int _get(int len) {
return (len+1)/(a+1);
} public void solve(InputReader in,PrintWriter out) {
n = in.nextInt();k = in.nextInt();a = in.nextInt();
m = in.nextInt();
myset.add(1);myset.add(n+1);
int ans = _get(n);
for (int i = 1; i <= m;i++) {
int x;
x = in.nextInt();
int r= (int)myset.higher(x);
int l = (int)myset.floor(x);
ans = ans-_get(r-l);
//l..x-1
if (l<=x-1) {
myset.add(x);
ans = ans + _get(x-1-l+1);
} //x+1..r-1
if (x+1<=r-1) {
myset.add(x+1);
ans = ans + _get(r-1-(x+1)+1);
}
if (ans<k) {
out.println(i);
return;
}
}
out.println(-1);
}
} static class InputReader{
public BufferedReader br;
public StringTokenizer tokenizer; public InputReader(InputStream ins) {
br = new BufferedReader(new InputStreamReader(ins));
tokenizer = null;
} public String next(){
while (tokenizer==null || !tokenizer.hasMoreTokens()) {
try {
tokenizer = new StringTokenizer(br.readLine());
}catch(IOException e) {
throw new RuntimeException(e);
}
}
return tokenizer.nextToken();
} public int nextInt() {
return Integer.parseInt(next());
}
}
}

最新文章

  1. CloudNotes:一个云端个人笔记系统
  2. org.hibernate.AssertionFailure:collection[......] was not processed by flush()
  3. Objective-C编码规范
  4. 安装、配置JDK的步骤
  5. 数据切分——Mysql分区表的建立及性能分析
  6. aapt不是内部命令
  7. 洛谷P3390【模板】矩阵快速幂——矩阵运算入门笔记
  8. Asp.NetMVC利用LigerUI搭建一个简单的后台管理详解(函登录验证)
  9. Bootstrap 4 网格的基本结构
  10. Azure DevOps Server/Team Foundation Server
  11. June 14. 2018 Week 24th Thursday
  12. windows 实用技巧
  13. spss入门
  14. Codeforces Round#412 Div.2
  15. Docker实战(五)之端口映射与容器互联
  16. A* 寻路的八个变种
  17. 什么是Spring框架? Spring框架有哪些主要的模块?
  18. 【bzoj2707】走迷宫
  19. Hush Framework框架配置(转)
  20. HDU 3726 Graph and Queries treap树

热门文章

  1. 1章 SpringBoot介绍
  2. ElasticSearch NEST
  3. 慕课网2-5 编程练习:通过jQuery通配符选择器进行文字变色
  4. Q - Euclid in Manhattan(欧几里德距离==曼哈顿距离?)
  5. [译]libcurl_tutorial
  6. Font Awesome 图标使用总结
  7. phpcms标签第三弹
  8. 百度AI车牌识别测试
  9. Indy 编译提示版本不一致问题的解决
  10. DIV自动居中