爱丽丝和鲍博喜欢玩一维战舰的游戏。他们在一行有n个方格的纸上玩这个游戏(也就是1×n的表格)。

在游戏开始的时候,爱丽丝放k个战舰在这个表格中,并不把具体位置告诉鲍博。每一只战舰的形状是 1×a 的长方形(也就是说,战舰会占据a个连续的方格)。这些战舰不能相互重叠,也不能相接触。

然后鲍博会做一系列的点名。当他点到某个格子的时候,爱丽丝会告诉他那个格子是否被某只战舰占据。如果是,就说hit,否则就说miss。

但是这儿有一个问题!爱丽丝喜欢撒谎。他每次都会告诉鲍博miss。

请你帮助鲍博证明爱丽丝撒谎了,请找出哪一步之后爱丽丝肯定撒谎了。

Input

  1. 单组测试数据。
  2. 第一行有三个整数n,ka(1n,k,a2*10^5),表示表格的大小,战舰的数目,还有战舰的大小。输入的n,k,a保证是能够在1×n的表格中放入k只大小为a的战舰,并且他们之间不重叠也不接触。
  3. 第二行是一个整数m(1mn),表示鲍博的点名次数。
  4. 第三行有m个不同的整数x1,x2,...,xmxi是鲍博第i次点名的格子编号。格子从左到右按照1n编号。

Output

  1. 输出一个整数,表示最早一次能够证明爱丽丝一定撒谎的点名编号。如果不能证明,输出-1。点名的编号依次从1m编号。
 
开始想的是每加入一个点名编号就重新统计可以放的战舰数,实际上只需要重新计算这个编号的左右区间就可以了。很容易想到的是用set二分查找,另外set不像vector有排序的概念,所以lower_bound(st.begin(),st.end(),x)是错误的,正确的是st.lower_bound(x)。。。我才发现stdio.h比cstdio快了不少(之前好多卡超时的题都A惹QAQ
  1. #include <stdio.h>
  2. #include <set>
  3. #include <iostream>
  4. using namespace std;
  5. const int N = ;
  6. set<int>S;
  7. int main()
  8. {
  9. int n, k, a, m, x, ans = -;
  10. bool f = ;
  11. cin>>n>>k>>a>>m;
  12. S.insert(n+);
  13. S.insert();
  14. int c = (n+)/(a+);//目前一共可放舰数
  15. for(int i=; i<=m; i++)
  16. {
  17. scanf("%d", &x);
  18. S.insert(x);
  19. //未找到撒谎编号进入
  20. if(!f)
  21. {
  22. set<int>::iterator it = S.lower_bound(x);
  23. set<int>::iterator it1 = it;
  24. it1--;//前一个点名编号
  25. set<int>::iterator it3 = it;
  26. it3++;//后一个点名编号
  27. int num = (*it3 - *it1)/(a+);//前后编号之间可以放的战舰数
  28. c -= num;
  29. c += (*it-*it1)/(a+)+(*it3-*it)/(a+);//加入该点名编后后总共可放的战舰数
  30. if(c < k)
  31. {
  32. ans = i;
  33. f = ;
  34. }
  35. }
  36. }
  37. printf("%d\n", ans);
  38. return ;
  39. }

还有一种方法不用set也可以解决。从这个编号向左右寻找最近的两个编号。

  1. #include <stdio.h>
  2.  
  3. using namespace std;
  4. const int N = ;
  5. int mp[N];
  6. int main()
  7. {
  8. int n, k, a, m, x, ans = -;
  9. bool f = ;
  10. scanf("%d%d%d%d", &n, &k, &a, &m);
  11. mp[] = , mp[n+] = ;
  12. int c = (n+)/(a+);//目前一共可放舰数
  13. for(int i=; i<=m; i++)
  14. {
  15. scanf("%d", &x);
  16. mp[x] = ;
  17. if(!f)
  18. {
  19. int j, l;
  20. for(j=x-; j>=&&!mp[j]; j--);
  21. for(l=x+; l<=n&&!mp[l]; l++);
  22. int num = (l - j)/(a+);
  23. c -= num;
  24. c += (x-j)/(a+)+(l-x)/(a+);
  25. if(c < k)
  26. {
  27. ans = i;
  28. f = ;
  29. }
  30. }
  31. }
  32. printf("%d\n", ans);
  33. return ;
  34. }

【51nod-1521】一维战舰的更多相关文章

  1. 51Nod 1521 一维战舰

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1521 思路:先计算出一开始最多能放多少艘战舰,然后每次输入一个点后,找到 ...

  2. 51 nod 1521 一维战舰 时间复杂度O(n),同 Codeforces 567D. One-Dimensional Battle Ships 有详细注释

    题目:51nod: 题目Codeforces: 题目注意到两个战舰不能挨在一起就可以了. // 每一段 struct node{ int left; // 段的左端点 int right; // 段的 ...

  3. 51 nod 1521 一维战舰(二分)

    传送门 题意 分析 这是我在51nod上的第2题,下载了4个数据,得不偿失?我太菜啦 一开始wa了6个点,下数据后发现舰与舰不能相邻,再交wa,发现l和r都没设好,再wa,发现check里面[1,b[ ...

  4. 51 Nod 一维战舰

    1521 一维战舰  题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题  收藏  关注 爱丽丝和鲍博喜欢玩一维战舰的游戏.他们在一行 ...

  5. 51nod水题记

    妈呀51nod已经刷不动了又开始跟bzoj一样总是得看题解了...那么发一下总结吧... 1051:最大子矩阵 #include<cstdio> #include<cstring&g ...

  6. 51nod 省选联测 R2

    51nod 省选联测 R2 上场的题我到现在一道都没A,等哪天改完了再写题解吧,现在直接写第二场的. 第二场比第一场简单很多(然而这并不妨碍我不会做). A.抽卡大赛:http://www.51nod ...

  7. [51Nod 1773] A国的贸易

    [51Nod 1773] A国的贸易 题目描述 A国是一个神奇的国家. 这个国家有 2n 个城市,每个城市都有一个独一无二的编号 ,编号范围为0~2n-1. A国的神奇体现在,他们有着神奇的贸易规则. ...

  8. ACM学习历程—51NOD 1412 AVL树的种类(递推)

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1770 这是这次BSG白山极客挑战赛的B题.设p(i, j)表示节点个数为 ...

  9. 51nod - 1278 相离的圆 (二分)

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1278 因为圆心都在x轴上,把每个圆转化成线段后,按线段的起点排序,那么对 ...

随机推荐

  1. 深拷贝与浅拷贝js,方法

    在使用JavaScript对数组进行操作的时候,我们经常需要将数组进行备份,事实证明如果只是简单的将它赋予其他变量,那么我们只要更改其中的任何一个,然后其他的也会跟着改变,这就导致了问题的发生. 参考 ...

  2. centos7 离线安装docker-ce

    测试的时候,在VM中安装了一个minimal安装的centos7.因为发现在已经安装好环境的系统中,执行下面,并不会下载依赖的rpm.#下载docker-ce和其需要的依赖rpm yum instal ...

  3. Salesforce视图与控制器之间的交互

    刚接触Salesforce,过程的确是比较艰难了,中文资料几乎没有,看英文资料学的效率却不高,不过看了一段时间的英文资料发现自己英语水平挺高不少啊,现在看都不用工具翻译,早知道就再次尝试报个6级,看下 ...

  4. SVN文件版本太旧问题解决

    错误信息如下: E155036: The working copy at '/Users/...' is too old (format 10) to work with client version ...

  5. js实现excel的解析

    在浏览网页的时候不小心看到了这个github的资源(https://github.com/SheetJS/js-xlsx),真不错.之前在开发的时候曾遇到客户要求在前端解析excel并展示出来.这里记 ...

  6. spark + yarn调试问题java.nio.channels.ClosedChannelException

    spark客户端提交任务至yarn,后台抛错,FinalStatus:UNDEFINED. ./spark-submit  --class org.apache.spark.examples.Spar ...

  7. php下获取http状态的实现代码

    在项目开发中,有时我们需要知道远程的URL地址是否能访问正常,判断其正常与否后进行下一步的操作,那么在PHP中如何获取远程HTTP的状态呢? 文件preg.php header("HTTP/ ...

  8. (java) 第二周学习总结

    在java源代码中,每个变量都必须声明一种类型(type).有两种类型:primitive type和reference type.引用类型引用对象(reference to object),而基本类 ...

  9. Java基础东西(按位操作运算)

    http://aokunsang.iteye.com/blog/615658 前奏:   昨天一哥们问我Java位移你会吗,我说不会,想想位移这么麻烦,一般有位移的Java代码一律不看,有几个人会啊, ...

  10. Hive常见问题

    1.HQL是否区分大小写 不区分 hive> select AGE from default.studeNT; --不区分大小写,即使是表中字段 2.查看创建表过程 show create ta ...