[bzoj2433][Noi2011]智能车比赛
【题目链接】
【题目大意】
题目已经讲得很清楚了
防剧透
防剧透
防剧透
防剧透
防剧透
防剧透
防剧透
防剧透
防剧透
【解题思路】
首先可以发现一个性质:路径的转折点只能在矩形的顶点上。这个可以用任意三角形内一点到两顶点的距离<另一点到这两顶点的距离来证明。
于是这个明显是有阶段性的,也即只能从左到右。于是可以Dp,当然也可以spfa或Dijkstra等等。
算法关键在于如何求出任意两点间的距离。
朴素做法要O(n^3),这明显是过不了的。
我们考虑从每个点开始走,发现每次阻挡视野的都是刚刚走过的矩形的边。于是我们可以维护一个视野,用每个访问过的点更新视野的up or low。
Postscript:记得加上等号……
#include <cstdio>
#include <algorithm>
#include <cmath>
typedef long long ll;
const int N = 2000 + 9;
struct Point
{
int x,y;
Point(const int _x = 0,const int _y = 0):
x(_x),y(_y){}
}p[N * 4],S,T;
int n,pre[N],start;
double dis[N*4],v;
inline ll sqr(const int x){return 1ll*x*x;}
inline double Dis(const Point x,const Point y)
{return std::sqrt(sqr(y.x-x.x) + sqr(y.y-x.y));}
inline ll cpr(const Point x,const Point y,const Point z)
{
const ll x1 = y.x - x.x, y1 = y.y - x.y;
const ll x2 = z.x - x.x, y2 = z.y - x.y;
return x1*y2 - x2*y1;
}
bool check(const int up,const int low,const Point x,const Point y)
{
if (up && cpr(x,p[up],y) > 0 || low && cpr(x,p[low],y) < 0) return false;
return true;
}
double Dijkstra()
{
static bool ins[N*4];
for (start = 1; start <= n; ++start)
if (p[start].x >= S.x) break;
for (int i = start--; i <= n; ++i) dis[i] = 99999999.0;
dis[start] = 0; p[start] = S; dis[4*N - 1] = 999999999.0; pre[start] = -1;
while (1) {
int k = 4*N - 1;
for (int i = start; i <= n; ++i)
if (!ins[i] && dis[k] > dis[i]) k = i;
if (n == k) return dis[k];
ins[k] = 1;
if (k == 7)
k = 7;
int up = 0,low = 0; double tmp;
for (int i = k + 1; i <= n; ++i) {
if (check(up,low,p[k],p[i]))
if (!ins[i] && dis[i] > (tmp = dis[k] + Dis(p[k],p[i])))
dis[i] = tmp;
if (((i-1)%4+1)&1 && (!up || cpr(p[k],p[up],p[i]) <= 0)) up = i;
else if (!(((i-1)%4+1)&1) && (!low || cpr(p[k],p[low],p[i]) >= 0)) low = i;
if (up && low && cpr(p[k],p[up],p[low]) > 0) break;
}
}
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("2433.in","r",stdin);
freopen("2433.out","w",stdout);
#endif
scanf("%d",&n);
for (int i = 1; i <= n; ++i) {
scanf("%d%d%d%d",&p[i*4-2].x,&p[i*4-2].y,&p[i*4-1].x,&p[i*4-1].y);
p[i*4-3] = Point(p[i*4-2].x,p[i*4-1].y);
p[i*4] = Point(p[i*4-1].x,p[i*4-2].y);
}
scanf("%d%d%d%d",&S.x,&S.y,&T.x,&T.y);
n *= 4;
if (S.x > T.x) std::swap(S,T);
for (; n; --n)
if (p[n].x <= T.x) break;
p[++n] = T;
scanf("%lf",&v);
printf("%.10f\n",Dijkstra()/v);
}
[bzoj2433][Noi2011]智能车比赛的更多相关文章
- 2433: [Noi2011]智能车比赛 - BZOJ
Description 新一届智能车大赛在JL大学开始啦!比赛赛道可以看作是由n个矩形区域拼接而成(如下图所示),每个矩形的边都平行于坐标轴,第i个矩形区域的左下角和右上角坐标分别为(xi,1,yi, ...
- Noi2011 : 智能车比赛
假设S在T左边,那么只能往右或者上下走 f[i]表示S到i点的最短路 f[i]=min(f[j]+dis(i,j)(i能看到j)) 判断i能看到j就维护一个上凸壳和一个下凸壳 时间复杂度$O(n^2) ...
- [NOI2011]智能车比赛 (计算几何 DAG)
/* 可以发现, 最优路径上的所有拐点, 基本上都满足一定的性质, 也就是说是在矩形上的拐角处 所以我们可以把他们提出来, 单独判断即可 由于我们提出来的不超过2n + 2个点, 我们将其按照x坐标排 ...
- 【[NOI2011]智能车比赛】(建图+spfa+坑爹精度)
过了这题我就想说一声艹,跟这个题死磕了将近6个小时,终于是把这个题死磕出来了.首先看到这个题的第一反应,和当初做过的一个房间最短路比较相似,然后考虑像那个题那样建边,然后跑最短路.(具体建边方法请参考 ...
- 【LOJ】#2443. 「NOI2011」智能车比赛
题解 显然是个\(n^2\)的dp 我们要找每个点不穿过非赛道区域能到达哪些区域的交点 可以通过控制两条向量负责最靠下的上边界,和最靠上的下边界,检查当前点在不在这两条向量之间即可,对于每个点可以\( ...
- BZOJ 2433 智能车比赛(计算几何+最短路)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2433 题意:若干个矩形排成一排(同一个x之上最多有一个矩形),矩形i和i+1相邻.给定两 ...
- 智能车学习(十五)——K60野火2013版例程
一.中断函数注册方法: 1.格式: 配置某个功能的中断 注册中断函数 开启中断 2.一个例子 pit_init_ms(PIT0,);//定时中断初始化 set_vector_handler(PIT0_ ...
- K60平台智能车开发工作随手记
(图片仅为示例,并不一定固定为这种造型) 第十二届全国大学生智能汽车竞赛有一个分项是光电四轮车的竞速(任务A),Seven她们组采购到的配件使用了freescale Crotex-M4内核的CPU,T ...
- 【sky第二期--PID算法】--【智能车论坛】
[sky第二期--PID算法] 想学PID的可以来[智能车论坛]这里有我发布的资料http://bbs.tekbots.eefocus.com/forum.php?mod=viewthread& ...
随机推荐
- 省队集训 Day7 选点游戏
[题目大意] 维护一个$n$个点的图,$m$个操作,支持两个操作: 1. 连接$(u, v)$这条边: 2. 询问$u$所在的联通块中,能选出的最大合法的点数. 一个方案是合法的,当且仅当对于所有被选 ...
- 汕头市队赛SRM 20 T2不净的圣杯
不净的圣杯 SRM 20 背景 作为一张BUG级别的卡,官方打算把它修改得人畜无害一些…… 虽然名字还没想好,但是能力大概是对敌方所有单位造成d点伤害,d为自己牌组中所有卡的编号的最大公约数.这无疑是 ...
- 【51NOD】数据流中的算法
[算法]数学 [题解] 1.平均数:累加前缀和.//听说要向下取整? 2.中位数:双堆法,大于中位数存入小顶堆,小于中位数存入大顶堆,保证小顶堆内数字数量≥大顶堆,奇数则取小堆顶,偶数则取两堆顶/2. ...
- 使用TSQL语句操作MySQL数据库
使用TSQL语句创建数据库 以前用的是鼠标在界面上手动创建,这样创建会比较麻烦,而且还会经常出问题.在其它电脑上要用的话还需要重复操作.所以要使用程序代码操作,能通过代码的就不用手动操作. 在数据库界 ...
- No 'Access-Control-Allow-Origin' Ajax跨域访问解决方案
No 'Access-Control-Allow-Origin' header is present on the requested resource. 当使用ajax访问远程服务器时,请求失败,浏 ...
- bzoj 1202 并查集
首先我们知道若干区间和信息,判断给出信息是否合法,可以用并查集维护,我们用dis[x]表示x到father[x]的距离为多少,即区间father[x]到x的长度,这样我们可以在路径压缩的时候维护dis ...
- js作用域与上下文
作用域:与调用函数,访问变量的能力有关 作用域分为:局部和全局(在局部作用域里可以访问到全局作用域的变量,但在局部作用域外面就访问不到局部作用里面所设定的变量) 上下文:与this关键字有关 是调用当 ...
- JS阶段测试
JS阶段测试 一.选择题 1.表单中的数据要提交到的处理文件由表单的( c )属性指定. A. method B. name C. action D. 以上都不对 2.在CSS样式 ...
- Linux 入门记录:四、Linux 系统常用命令
一.日期时间 命令 date 查看.设置当前系统时间: date -u 格林威治时间 date %Y-%m-%d 显示格式化的时间 date -s "23:00" 使用 -s 参数 ...
- 获取并编译最新的Notepad++源码
获取并编译最新的Notepad++源码 http://blog.csdn.net/u012814856/article/details/68947310 Notepad++源码编译及其分析 http: ...