【BZOJ3627】【JLOI2014】路径规划 分层图
意甲冠军:要查找。有门户网站:http://www.lydsy.com/JudgeOnline/problem.php?
id=3627
注意:点的等待时长示意图为:
非常清晰了吧?没事,不清晰就不清晰吧。反正公式给你了,这不是本题知识点。扒即可了。
题解:
看到这题的数据范围。我们就想到了分层图。但是如今有两种须要分层的东西:剩余油量的限制。和经过红绿灯的限制。所以我们要搞掉当中一个,使题目转化成分层图。红绿灯限制非常不好惹的样子,所以我们还是把剩余油量的限制搞掉吧。
怎么搞掉油量的限制呢?我们能够把整个图缩成一个仅仅有加油站的图,这样两加油站之间仅仅要能够直接到达,就不用再管【剩余油量】了!
当然,起点和终点也要算到加油站中,至于终点可能多加的一份【加油费用】。再删掉就好了~
详细做法:非常easy地说。。枚举每一个加油站,看满油从它出发能跑到哪些点,然后建边(新图的边,点为加油站的图的边)。而两点之间依据经过红绿灯的不同。所以可能有多条边。
。再简单一点的说法就是——看下述代码!
!
好了,新图建好了,跑一遍水水的分层图吧。
就是dist[i][j]表示到j时经过i个红绿灯的最短路径,至于若j有红灯时算不算上神马的就不用写得太拘束了,爱怎么写怎么写。题目到这里已经非常水了。
。
注意:
我们在预处理节点名称的时候最好还是建一棵字典树。这样找起来会非常快。代码也非常好写。
不然可能就须要写一发pq优化的nlogn最短路。哪个好写,自己想吧。另。假设想刷rank。这两个都得写!!!
假设不会分层图的话。最好还是看看这一篇:http://blog.csdn.net/vmurder/article/details/40075989
好了。直接贴代码,写得比較清晰,仅仅是由于代码量的缘故才会看着发晕。认真细致一点非常easy看懂(大不了你用例子数据手调一下我的代码!不信看不懂!
)
(原题数据范围错了,n和m都应该是原来的2倍。)
/**************************************************************
Problem: 3627
User: 18357
Language: C++
Result: Accepted
Time:716 ms
Memory:69628 kb
****************************************************************/ #include <queue>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define N 10100
#define M 20100
#define P 60
#define TT 80
#define eps 1e-7
#define inf 0x3f3f3f3f
using namespace std;
/*i won't tell you it's a trie. */
struct Trie
{
int next[N*20][TT],cnt;
int note[N*20],sign;
char s[TT];
inline int insert()
{
scanf("%s",s+1);
int x=0,i,alp;
for(i=1;s[i];i++)
{
alp=s[i]-'0';
if(!next[x][alp])next[x][alp]=++cnt;
x=next[x][alp];
}
if(!note[x])note[x]=++sign;
return note[x];
}
inline int judge()
{
for(int i=1;s[i];i++)if(i>=5&&s[i]=='t'&&s[i-1]=='r'&&s[i-2]=='a'&&s[i-3]=='t'&&s[i-4]=='s')return 1;
for(int i=1;s[i];i++)if(i>=3&&s[i]=='s'&&s[i-1]=='a'&&s[i-2]=='g')return 2;
for(int i=1;s[i];i++)if(i>=3&&s[i]=='d'&&s[i-1]=='n'&&s[i-2]=='e')return 3;
return 0;
}
}trie;
/*for original graph or prespfa or the gas_station graph. */
struct KSD
{
int u,v,next;
double len;
}e[M<<1],E[15][P*P<<1];
int head[N],cnt;
void add(int u,int v,double len)
{
cnt++;
e[cnt].u=u;
e[cnt].v=v;
e[cnt].len=len;
e[cnt].next=head[u];
head[u]=cnt;
}
int HEAD[15][P],CNT[15];
void ADD(int light,int u,int v,double len)
{/*i feel sick for my code here, but i can't do anything. */
CNT[light]++;
E[light][CNT[light]].u=u;
E[light][CNT[light]].v=v;
E[light][CNT[light]].len=len;
E[light][CNT[light]].next=HEAD[light][u];
HEAD[light][u]=CNT[light];
}
struct Lux
{
int x,y;
Lux(int _x,int _y):x(_x),y(_y){}
Lux(){}
};
queue<Lux>q;
double dist[15][N];
bool in[15][N];
/*for static code*/
int n,m,lig,gas,cost;
/*for each point*/
bool red[N];
int sta[N];
double ave[N];
int gas_station[N],num;
/*for temp input*/
char ttt[TT]; void prespfa(int S)
{/*build the direct combinations between the gas_stations. */
while(!q.empty())q.pop();
memset(dist,0x7f,sizeof(dist));
int i,v,temp;
dist[0][S]=0;
in[0][S]=1;
q.push(Lux(0,S));
while(!q.empty())
{
Lux U=q.front();q.pop();in[U.x][U.y]=0;
for(i=head[U.y];i;i=e[i].next)
{
v=e[i].v;
temp=U.x+red[v];
if(temp<=lig&&dist[U.x][U.y]+e[i].len+ave[v]<=gas&&dist[temp][v]>dist[U.x][U.y]+e[i].len+ave[v])
{
dist[temp][v]=dist[U.x][U.y]+e[i].len+ave[v];
if(!in[temp][v])in[temp][v]=1,q.push(Lux(temp,v));
}
}
}
}
double divspfa(int S,int T)
{
while(!q.empty())q.pop();
memset(dist,0x7f,sizeof(dist));
int i,j,v,temp;
dist[0][S]=0;
in[0][S]=1;
q.push(Lux(0,S));
while(!q.empty())
{
Lux U=q.front();q.pop();in[U.x][U.y]=0;
for(j=0;j+U.x<=lig;j++)
{
for(i=HEAD[j][U.y];i;i=E[j][i].next)
{
v=E[j][i].v;
if(dist[j+U.x][v]>dist[U.x][U.y]+E[j][i].len+cost)
{
dist[j+U.x][v]=dist[U.x][U.y]+E[j][i].len+cost;
if(!in[j+U.x][v])in[j+U.x][v]=1,q.push(Lux(j+U.x,v));
}
}
}
}
double ret=99999999999.999;
for(i=0;i<=lig;i++)ret=min(ret,dist[i][T]);
return ret;
} void work()
{
int i,j,k;
double a,b,c;
int ia,ib;
int s,t,v;
/*i just think it's not
[graceful]
to input in the main function. */
scanf("%d%d%d%d%d",&n,&m,&lig,&gas,&cost);
for(i=1;i<=n;i++)
{
trie.insert();
if(k=trie.judge())
{
sta[i]=++num;
gas_station[num]=i;
if(k==1)s=i;
if(k==3)t=i;
}
scanf("%lf%lf",&a,&b);
if(k==1||k==3)continue;
if(a>eps)
red[i]=1,ave[i]=a*a/2.0/(a+b);
}
for(i=1;i<=m;i++)
{
ia=trie.insert();
ib=trie.insert();
scanf("%s",ttt);
scanf("%lf",&c);
add(ia,ib,c);
add(ib,ia,c);
} for(i=1;i<=num;i++)
{
prespfa(gas_station[i]);
for(j=1;j<=num;j++)
{
v=gas_station[j];
if(j!=i)
{
for(k=0;k<=lig;k++)
{
if(dist[k][v]<inf)
{
ADD(k,i,j,dist[k][v]);
}
}
}
}
}
printf("%.3lf\n",divspfa(sta[s],sta[t])-cost);
} int main()
{
// freopen("pathplan.in","r",stdin);
// freopen("pathplan.out","w",stdout);
// freopen("test.in","r",stdin);
work();
return 0;
}
版权声明:本文博主原创文章,博客,未经同意不得转载。
【BZOJ3627】【JLOI2014】路径规划 分层图的更多相关文章
- 【BZOJ-3627】路径规划 分层图 + Dijkstra + spfa
3627: [JLOI2014]路径规划 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 186 Solved: 70[Submit][Status] ...
- BZOJ3627: [JLOI2014]路径规划
BZOJ3627: [JLOI2014]路径规划 Description 相信大家都用过地图上的路径规划功能,只要输入起点终点就能找出一条最优路线.现在告诉你一张地图的信息,请你找出最优路径(即最短路 ...
- 机器人路径规划其一 Dijkstra Algorithm【附动态图源码】
首先要说明的是,机器人路径规划与轨迹规划属于两个不同的概念,一般而言,轨迹规划针对的对象为机器人末端坐标系或者某个关节的位置速度加速度在时域的规划,常用的方法为多项式样条插值,梯形轨迹等等,而路径规划 ...
- 机器人路径规划其二 A-Star Algorithm【附动态图源码】
首先要说明的是,机器人路径规划与轨迹规划属于两个不同的概念,一般而言,轨迹规划针对的对象为机器人末端坐标系或者某个关节的位置速度加速度在时域的规划,常用的方法为多项式样条插值,梯形轨迹等等,而路径规划 ...
- [ML] 高德软件的路径规划原理
路径规划 Dijkstra s:起点:S:已知到起点最短路径的点:U:未知到起点最短路径的点 Step 1:S中只有起点s,从U中找出路径最短的 Step 2:更新U中的顶点和顶点对应的路径 重复St ...
- 基于谷歌地图的Dijkstra算法水路路径规划
最终效果图如下: 还是图.邻接表,可以模拟出几个对象=>节点.边.路径.三个类分别如下: Node 节点: using System; using System.Collections.Gene ...
- iOS百度地图路径规划和POI检索详细总结-b
路径规划.png 百度地图的使用 百度地图API的导入网上说了许多坑,不过我遇到的比较少,这里就放两个比较常见的吧.坑一: 奥联WIFI_xcodeproj.png 如上图所示,在infoplist里 ...
- Bzoj 2662: [BeiJing wc2012]冻结 dijkstra,堆,分层图,最短路
2662: [BeiJing wc2012]冻结 Time Limit: 3 Sec Memory Limit: 128 MBSubmit: 647 Solved: 348[Submit][Sta ...
- ROS探索总结(十四)——move_base(路径规划)
在上一篇的博客中,我们一起学习了ROS定位于导航的总体框架,这一篇我们主要研究其中最重要的move_base包. 在总体框架图中可以看到,move_base提供了ROS导航的配置.运行.交互接口,它主 ...
随机推荐
- SQL:多表关联采取这一纪录迄今为止最大
笔者:iamlasong 1.需求 两个表,投递记录表和封发开拆记录表,如今想知道投递日期距最后一次封发日期天数分布情况. 对这个需求,须要先查询出投递明细,同一时候要知道相应的邮件最后一次封发情况. ...
- Windows Phone开发(4):框架和页
原文:Windows Phone开发(4):框架和页 在开如之前,我想更正一个小问题,之前我在第一篇文章中说,Visual Studio Express for Windows Phone的中文版没有 ...
- wpa/wpa2破解系统(CDlinux)U盘启动傻瓜教程
CDlinux是破解无线wifi信号的很好用的系统.它就像一个PE,不过它是基于Linux内核的微型系统.里面的破解工具很齐全,既有传统的抓包工具,也有最新的PIN码破解软件,而且针对windows用 ...
- 【原创】leetCodeOj --- Binary Search Tree Iterator 解题报告
时间挤挤总是有的 太久不做题,脑子都生锈了.来道水题练练手 题目地址: https://leetcode.com/problems/binary-search-tree-iterator/ 题目内容: ...
- Foursquare 8.0 :聪明人给互联网公司上的流量转化课
今年 5 月上线的 Swarm 虽然应用制作精良,但不免让人怀疑是 Foursquare一次失败的互联网公司服务越界和用户忠诚度试水.但非常快这群聪明人让我们发现事情并没有这么简单:他们给互联网公司们 ...
- Lua语言在Wireshark中使用(转)
1. 检查Wireshark的版本是否支持Lua 打开Wireshark,点击“HelpàAbout Wireshark”菜单,查看弹出的对话框,如果有“with Lua 5.1”表示支持 ...
- HDU 1051:Wooden Sticks
Wooden Sticks Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
- _00013 一致性哈希算法 Consistent Hashing 新的讨论,并出现相应的解决
笔者博文:妳那伊抹微笑 博客地址:http://blog.csdn.net/u012185296 个性签名:世界上最遥远的距离不是天涯,也不是海角,而是我站在妳的面前.妳却感觉不到我的存在 技术方向: ...
- facade pattern
外观模式是一种使用频率非常高的设计模式,它通过引入一个外观角色来简化客户端与子系统之间的交互,为复杂的子系统调用提供一个统一的入口,使子系统与客户端的耦合度降低,且客户端调用非常方便.外观模式并不给系 ...
- BZOJ 2006 NOI2010 超级钢琴 划分树+堆
题目大意:给定一个序列.找到k个长度在[l,r]之间的序列.使得和最大 暴力O(n^2logn),肯定过不去 看到这题的第一眼我OTZ了一下午... 后来研究了非常久别人的题解才弄明确怎么回事...蒟 ...