题目名称 | 2635. [天梯赛PAT]长城 |
---|---|
输入输出 | gfw.in/out |
难度等级 | ★☆ |
时间限制 | 400 ms (0.4 s) |
内存限制 | 256 MiB |
测试数据 | 10 |
题目来源 | cstdio 于2017-03-18加入 |
开放分组 | 全部用户 |
提交状态 | |
分类标签 | |
分享题解 |
通过:4, 提交:9, 通过率:44.44% | ||||
kito | 100 | 0.062 s | 2.29 MiB | C++ |
Go灬Fire | 100 | 0.124 s | 3.32 MiB | C++ |
cstdio | 100 | 0.421 s | 2.32 MiB | C++ |
cstdio | 100 | 0.424 s | 2.32 MiB | C++ |
kito | 70 | 1.488 s | 1.81 MiB | C++ |
kito | 30 | 0.088 s | 1.81 MiB | C++ |
cstdio | 30 | 0.435 s | 1.84 MiB | C++ |
kito | 10 | 0.104 s | 1.05 MiB | C++ |
Go灬Fire | 10 | 0.120 s | 3.32 MiB | C++ |
关于 长城 的近10条评论(全部评论) | ||||
---|---|---|---|---|
苟利国家生死以,膜拜神犇wmd
文件名亮了
Albert S. Chang
2017-04-02 20:26
5楼
| ||||
回复 @zyf :
太神辣!太神辣!太神辣!
rvalue
2017-03-30 20:55
4楼
| ||||
回复 @zyf :
大新闻: “初中生2015”分组的神犇教训wmd!这一切的一切,是因为“长江后浪推前浪,一代更比一代浪,把萌帝拍翻在沙滩上!”,还是由“在新时期OI社会的主要矛盾”引起?更多详情请见《人民日报》社会焦点专栏。
_Itachi
2017-03-30 20:07
3楼
| ||||
回复 @cstdio : 别骂人
zyf
2017-03-30 19:58
2楼
| ||||
一开始写成了“只检查前一个”(错误的代码我也交上来了),见这个数据:
8 10 5 6 5 5 -9 4 -6 -2 4 -3 -10 -8 5 -9 5 答案=2,而非3 顺便说一句,PAT上的数据真他娘的弱啊…… |
正如我们所知,中国古代长城的建造是为了抵御外敌入侵。在长城上,建造了许多烽火台。每个烽火台都监视着一个特定的地区范围。一旦某个地区有外敌入侵,值守在对应烽火台上的士兵就会将敌情通报给周围的烽火台,并迅速接力地传递到总部。
现在如图1所示,若水平为南北方向、垂直为海拔高度方向,假设长城就是依次相联的一系列线段,而且在此范围内的任一垂直线与这些线段有且仅有唯一的交点。
进一步地,假设烽火台只能建造在线段的端点处。我们认为烽火台本身是没有高度的,每个烽火台只负责向北方(图1中向左)瞭望,而且一旦有外敌入侵,只要敌人与烽火台之间未被山体遮挡,哨兵就会立即察觉。当然,按照这一军规,对于南侧的敌情各烽火台并不负责任。一旦哨兵发现敌情,他就会立即以狼烟或烽火的形式,向其南方的烽火台传递警报,直到位于最南侧的总部。
以图2中的长城为例,负责守卫的四个烽火台用蓝白圆点示意,最南侧的总部用红色圆点示意。如果红色星形标示的地方出现敌情,将被哨兵们发现并沿红色折线将警报传递到总部。当然,就这个例子而言只需两个烽火台的协作,但其他位置的敌情可能需要更多。 然而反过来,即便这里的4个烽火台全部参与,依然有不能覆盖的(黄色)区域。
另外,为避免歧义,我们在这里约定,与某个烽火台的视线刚好相切的区域都认为可以被该烽火台所监视。以图3中的长城为例,若A、B、C、D点均共线,且在D点设置一处烽火台,则A、B、C以及线段BC上的任何一点都在该烽火台的监视范围之内。
好了,倘若你是秦始皇的太尉,为不致出现更多孟姜女式的悲剧,如何在保证长城安全的前提下,使消耗的民力(建造的烽火台)最少呢?
输入格式:
输入在第一行给出一个正整数N(3 <= N <=105),即刻画长城边缘的折线顶点(含起点和终点)数。随后N行,每行给出一个顶点的x和y坐标,其间以空格分隔。注意顶点从南到北依次给出,第一个顶点为总部所在位置。坐标为区间 [-109, 109) 内的整数,且没有重合点。
输出格式:
在一行中输出所需建造烽火台(不含总部)的最少数目。
输入样例:10 67 32 48 -49 32 53 22 -44 19 22 11 40 10 -65 -1 -23 -3 31 -7 59输出样例:
2