题意是描述是这样的,给你n个围栏,对于每个围栏你必须走到其边上才可以往下跳,现在问你从初始最高位置的n个围栏,到原点,水平走过的路程最少是多少?

其实我可可以这样来考虑问题。由于每次都是从板子的左右两端往下面跳,我们可以从1到n有序的加入每一块板子(相当于对区间染色),加入每块板子查询一下它的两端的下面的点是什么。有了这个操作我们就可以直接预处理出来从每一块板子左右两端跳下来会落在那一块板子上面。

那应该用什么办法来实现这个查询和更新呢?显然,线段树。

下面我们等于是分别从第n块板子的左右端点往下走,然后求到原点的水平最短路了,直接一遍SPFA搞定。

上代码吧,下面省略若干个字。

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#define maxn 200100
using namespace std; const int add=;
int n,S,ans;
int l[maxn],r[maxn],fl[maxn],fr[maxn],pl[maxn],pr[maxn];
int a[*maxn],col[*maxn];
bool inq[maxn]; int abs(int x)
{
return x>=?x:-x;
} void PushDown(int rt)
{
if (col[rt]==-) return;
col[rt<<]=col[rt<<|]=col[rt];
col[rt]=-;
} void update(int rt,int l,int r,int L,int R,int id)
{
if (L<=l && R>=r)
{
col[rt]=id;
return;
}
PushDown(rt);
int mid=(l+r)>>;
if (L<=mid) update(rt<<,l,mid,L,R,id);
if (R> mid) update(rt<<|,mid+,r,L,R,id);
} int query(int rt,int l,int r,int pos)
{
if (l<=pos && r>=pos && col[rt]>=) return col[rt];
PushDown(rt);
int mid=(l+r)>>;
if (pos<=mid) return query(rt<<,l,mid,pos);
else return query(rt<<|,mid+,r,pos);
} void bfs()
{
fl[n]=S-l[n],fr[n]=r[n]-S;
queue<int> Q;
Q.push(n);
while (!Q.empty())
{
int cur=Q.front();
Q.pop(),inq[cur]=false;
int next1=pl[cur],next2=pr[cur]; if (next1==) ans=min(ans,fl[cur]+abs(add-l[cur]));
else
{
if (fl[cur]+l[cur]-l[next1]<fl[next1] || fl[cur]+r[next1]-l[cur]<fr[next1])
{
fl[next1]=min(fl[next1],fl[cur]+l[cur]-l[next1]);
fr[next1]=min(fr[next1],fl[cur]+r[next1]-l[cur]);
if (!inq[next1]) Q.push(next1),inq[next1]=true;
}
} if (next2==) ans=min(ans,fr[cur]+abs(add-r[cur]));
else
{
if (fr[cur]+r[cur]-l[next2]<fl[next2] || fr[cur]+r[next2]-r[cur]<fr[next2])
{
fl[next2]=min(fl[next2],fr[cur]+r[cur]-l[next2]);
fr[next2]=min(fr[next2],fr[cur]+r[next2]-r[cur]);
if (!inq[next2]) Q.push(next2),inq[next2]=true;
}
}
}
} int main()
{
//while (scanf("%d%d",&n,&S)!=EOF)
{
scanf("%d%d",&n,&S);
S+=add;
memset(fl,0x3f,sizeof fl);
memset(fr,0x3f,sizeof fr);
for (int i=; i<=n; i++)
{
scanf("%d%d",&l[i],&r[i]);
l[i]+=add,r[i]+=add;
pl[i]=query(,,maxn,l[i]);
pr[i]=query(,,maxn,r[i]);
update(,,maxn,l[i],r[i],i);
}
ans=~0U>>;
bfs();
printf("%d\n",ans);
}
return ;
}

POJ2374_Fence Obstacle Course的更多相关文章

  1. hdu 3152 Obstacle Course

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3152 Obstacle Course Description You are working on t ...

  2. [转] The Single Biggest Obstacle to Trading Success

    Why do some people succeed spectacularly in the market while others fail? The market is the same for ...

  3. BZOJ 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课( BFS )

    BFS... 我连水题都不会写了QAQ ------------------------------------------------------------------------- #inclu ...

  4. BZOJ 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课

    题目 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课 Time Limit: 5 Sec  Memory Limit: 64 MB Description 考虑一 ...

  5. 碰撞回避算法(一) Velocity Obstacle

    碰撞回避是机器人导航,游戏AI等领域的基础课题.几十年来,有很多算法被提出.注意这里主要指的是局部的碰撞回避算法.尽管和全局的路径规划算法(A*算法等)有千丝万缕的联系.可是还是有所不同的(局部的碰撞 ...

  6. 1644: [Usaco2007 Oct]Obstacle Course 障碍训练课

    1644: [Usaco2007 Oct]Obstacle Course 障碍训练课 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 383  Solved ...

  7. 障碍路线Obstacle Course

    P1649 [USACO07OCT]障碍路线Obstacle Course 裸的dfs,今天学了一个新招,就是在过程中进行最优性减枝. #include<bits/stdc++.h> us ...

  8. Velocity Obstacle

    [Velocity Obstacle] Two circular objects A,B, at time t(0), with velocity V(A),V(B). A represent the ...

  9. bzoj1644 / P1649 [USACO07OCT]障碍路线Obstacle Course

    P1649 [USACO07OCT]障碍路线Obstacle Course bfs 直接上个bfs 注意luogu的题目和bzoj有不同(bzoj保证有解,还有输入格式不同). #include< ...

随机推荐

  1. 20155233 2006-2007-2 《Java程序设计》第3周学习总结

    20155233 2006-2007-2 <Java程序设计>第3周学习总结 教材学习内容总结 第四.五章主要学习Java如何产生对象,包括如何去定义一个类,如何去构造函数实现对象初始化流 ...

  2. 20155315庄艺霖第三次作业之Linux初体验

    Linux初体验 安装Linux三两事 老师的作业要求基于VirtualBox安装Linux系统,我一开始下载了VB但是电脑运行不了,后来看网上的教程下载了VMware,才算开始了我的Linux之旅. ...

  3. 【HDU4565】So Easy!

    [HDU4565]So Easy! 题面 要你求 \[ \lceil (a+\sqrt b)^n \rceil \% m \] 其中\(0<a,m<2^{15},(a-1)^2<b& ...

  4. js Date对象要注意的问题(时间转换)

    1.时间戳和时间对象可以灵活转变: let n = new Date() // 返回的是当前时间对应的国际时间 let nt =n.getTime() let n2 =new Date(nt) con ...

  5. 一个非常好用的PHP数组函数

    array_column 该函数非常有用,在PHP 5.5中可直接调用. 有如下二维数组,如要抽取每个子数组中的特定项. <?php // Array representing a possib ...

  6. Q&As:1.cocos2d-html5如何获得鼠标划过事件

    不喜欢按部就班学东西,感觉各种框架各种技术就应该是拿到手用的,这应该是导致我现在学了这么多却没一样精通的缘故吧. 发现自己喜欢在QQ群回答一些菜鸟的问题,就算自己不清楚也会乐意看代码帮助解决╮(╯_╰ ...

  7. MySQL数据库之安装,基本操作

    一.基础部分 1.数据库是什么 之前所学,数据要永久保留,比如用户注册的用户信息,都是保存于文件,而文件只能存在于某一台机器上. 如果我们不考虑从文件中读取数据的效率问题,并且假设我们的程序所有的组件 ...

  8. ----------BMI指数小程序----------

    # 1.创建并输出菜单, 菜单是不可变的. 所以使用元组# menus = ("1, 录入", "2, 查询", "3, 删除", &quo ...

  9. Saving James Bond - Easy Version (MOOC)

    06-图2 Saving James Bond - Easy Version (25 分) This time let us consider the situation in the movie & ...

  10. 3星|《十大全球CEO亲授企业高速成长的关键战略》:作为CEO,我也非常坦率地表明过家庭优先于工作

    十大全球CEO亲授 企业高速成长的关键战略(<哈佛商业评论>增刊) <哈佛商业评论>上的10来篇文章合集.大部分都看过,除了一篇中信的访谈,其他大部分是美国的有点旧的案例. 总 ...