TRAFFIC LIGHTS POJ 1158
题目大意:
在Dingilville 城市安排是一种不同寻常的方式,每个交叉路口有一条道路连接,一条道路最多连接两个不同的交叉路口。每个交叉路口不能连接他自己。道路旅行一端到另一端的时间是相同的,任何一个交叉路口都有一个红绿灯,它在任意时刻只能有红色或者绿色。当且仅当两个交叉路口的灯的颜色一样的时候才允许从一个交叉路口到达另一个交叉路口。如果一辆车到达一个交叉路口的时候这个灯刚好转换,那么它必须考虑这个灯的颜色。允许车辆在交叉路口等待。
给你这个城市的地图如下:
所有道路的通过时间是整数,每个交叉路口的红绿灯转换时间也是整数 并且所有灯光转换的时间也是整数。你的任务是从源点到终点你所行驶的车辆必须找到一个最短的时间到达,也许果有多个你值要输出其中一个就行。
输入数据:
2 <= N <=300 是 N个节点的编号。 编号是从1->N
1 <=M <=14,000 M 是道路的数量
1 <= lij <= 100 从i 到j的距离
1 <= tic <= 100 代表c颜色在节点 i 的持续时间
1 <= ric <= tic 代表颜色c 在节点 i 的剩余时间
第一行两个整数,一个是源点的编号,一个是终点的编号。
第二行包含两个整数。 一个是N, M。
接下来是N行代表是 N个交叉路口。
每行有 Ci, ric, tiB, tiP , Ci 是 是 'B' 或者是 ‘P’ 代表红绿灯的最初颜色, ric 代表颜色c剩余的时间, tiP 代表颜色 P 持续的时间, tiB 代表颜色 B 持续的 时间。
接下来是M行代表 从节点 i 到节点 j 的距离是 l
输出:
如果存在从源点到终点的路径那么我们输出所花费的最小时间, 否则输出 0
题目分析:
最短路不说了 SPFA水过, 难点就是判断从一个点到另一个点的时候需要判断两灯是否一样,假如一样 就能走, 否则不能过。
不能过的时候 在那等待, 一直到等到能过的时候再走, 将等待的时间加上就能算出来。
算等待的时间的时候我是暴力水过的, 也就是暴力判断每一秒是否会出现相同的灯, 假如出现了,返回这个点的时间有一点是要注意的, 假如两个点的灯是一样了, 这一秒也是能走的, 就是错在这WA了一天, 最后写了个简单的数据算是水过去了。
下面是代码 + 注释
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <queue>
#include <cmath>
#include <cstring>
using namespace std;
#define INF 0xfffffff
#define maxn 520
struct Point
{
char color[];//当前路灯的颜色 1 B 0 P
int R;
int P;// 颜色 P 持续的时间
int B;//颜色 B 持续的时间
} P[maxn]; struct Edge
{
int e, w;
Edge(int e=,int w=) :e(e), w(w) {}
};
vector<Edge> G[maxn]; bool vis[maxn];
int dist[maxn];
int Star, End;
int n, m;
char GetColor(Point A, int time)//得到这个时间点 这个红绿灯的颜色
{
int timeA = time - A.R; if(timeA <= )
return A.color[]; timeA = timeA%(A.B + A.P); if(timeA == )
timeA = A.B + A.P; if( A.color[] == 'B')
{
if(timeA <= A.P)
return 'P';
else
return 'B';
}
else
{
if(timeA <= A.B)
return 'B';
else
return 'P';
} }
int GetTime(Point A, Point B,int time)//得到两点红绿灯相同的时间
{
if(A.B == B.P && A.P == B.B && A.color[] != B.color[] && A.R == B.R )//这是不可能相同的情况 予以排除
return INF; while()//时间向上累加, 一直得到相同为止
{
time ++;//时间要先 + 1, 因为我传来的时间是我已经用掉过的时间, 所以要判断他的后一秒
if(GetColor(A,time) == GetColor(B,time) )
return time-;//到达这一点的时候是可以走的, 但是这一点不应算在时间花费内, 因为时间还未过
} }
void Spfa()// SPFA不再赘述, 关键是看两个点之间如何走
{
Edge Pa, Pn;
queue<Edge> Q;
dist[Star] = ;
Q.push( Edge(Star,) ); while( !Q.empty() )
{
Pa = Q.front();
Q.pop();
vis[Pa.e] = false;
int len = G[Pa.e].size(); for(int i=; i<len; i++)
{
Pn = G[Pa.e][i]; int time = GetTime(P[Pa.e], P[Pn.e], dist[Pa.e]) + Pn.w;//得到两个灯一样的最短时间 + 路程时间 更新 dist数组 if(dist[Pn.e] > time)
{
dist[Pn.e] = time; if( !vis[Pn.e] )
{
vis[Pn.e] = true;
Q.push(Pn);
}
}
}
}
}
void Init()
{
for(int i=; i<=n; i++)
{
G[i].clear();
vis[i] = false;
dist[i] = INF;
}
} int main()
{ while(cin >> Star >> End )
{
cin >> n >> m; Init(); for(int i=; i<=n; i++)
{
scanf("%s%d%d%d",P[i].color,&P[i].R,&P[i].B,&P[i].P);
} for(int i=; i<m ; i++)
{
int a, b, c;
scanf("%d%d%d",&a,&b,&c); G[a].push_back( Edge(b,c) );
G[b].push_back( Edge(a,c) );
} Spfa(); if(dist[End] == INF)
cout << << endl;
else
cout << dist[End] << endl;
}
return ;
}
TRAFFIC LIGHTS POJ 1158的更多相关文章
- Traffic Lights
Traffic Lights time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...
- 快速切题 sgu103. Traffic Lights 最短路 难度:1
103. Traffic Lights Time limit per test: 0.25 second(s)Memory limit: 4096 kilobytes input: standardo ...
- sgu 103 Traffic Lights 解题报告及测试数据
103. Traffic Lights Time limit per test: 0.25 second(s) Memory limit: 4096 kilobytes 题解: 1.其实就是求两点间的 ...
- POJ1158 城市交通Traffic lights IOI 1999 (最短路)
POJ1158 城市交通Traffic lights IOI 1999 (最短路) (1) 问题描述(probolem) 在d城里交通的安排不同寻常,城中有路口和路口之间的道路,再任意两个不同的路口之 ...
- sgu 103 Traffic Lights
这道题难得不是算法,而是处理. 题意就是让你求最短路,只有当两个点在某一秒颜色相同时,这条边才可以通行,输入首先给你 起点和终点, 然后给你 点数和边数, 接下来 n 行 初始颜色,初始颜色持续时间, ...
- Traffic Lights - SGU 103(最短路)
题目大意:有一个城市的路线图,有N个交叉点,每两个交叉点之间只有一条路,现在想从交点u去交点v,不过这个路的交通比较特别,每个路都有一个交通灯,灯有两种颜色,蓝色和紫色,例如一条路线在交点s,t之间, ...
- SGU 103.Traffic Lights(最短路)
时间: 0.50 second(s) 空间: 4096 kilobytes 输入: 标准输入 输出: 标准输出 Dingiville 城市的交通规则非常奇怪,城市公路通过路口相连,两个不同路口之间最多 ...
- SGU103+POJ 1158 最短路/dp
题意:一个无向图,求起点到终点最少时间,限制:每个路口有灯,要灯颜色一样才能过去,灯之有俩种颜色,周期 变化,给定每个灯初态,时间. 思路:开始就想到直接DP,方程dp[k]=dp[i]+distan ...
- 【codeforces 29B】Traffic Lights
[题目链接]:http://codeforces.com/problemset/problem/29/B [题意] 一辆车; 让从A开到B; 然后速度是v; (只有在信号灯前面才能停下来..否则其他时 ...
随机推荐
- 使用Tcl脚本分配FPGA管脚
自己主动生成Tcl文件 Project -> Generate Tcl File for Project... 弹出例如以下对话框.设置脚本路径. 编辑引脚 使用set_location_ass ...
- Gradle Import Wizard--官方文档
Last updated and checked to work with version 3.0.0 of the tools This tutorial will take you through ...
- Android(java)学习笔记237:多媒体之图形的变化处理
1.图形的缩放 (1)布局文件activity_main.xml如下: <LinearLayout xmlns:android="http://schemas.android.com/ ...
- Python操作MySQL -即pymysql/SQLAlchemy用法
本节介绍Python对于MySQL的一些操作用法 模块1:pymysql(等同于MySQLdb) 说明:pymysql与MySQLdb模块的使用基本相同,学会pymysql,使用MySQLdb也就不是 ...
- 设计模式UML图
1.简单工厂模式 2.工厂模式 工厂模式与简单工厂模式的不同在于,每个操作类都有自己的工厂,而且把逻辑判断交给了客户端,而简单工厂的逻辑判断在工厂类里边,当增加新的操作类时,简单工厂需要修改工厂类,而 ...
- CSS实现背景透明而背景上的文字不透明完美解决
在我们设计制作一些网页的时候可能会用到半透明的效果,首先我们可能会想到用PNG图片处理,当然这是一个不错的办法,唯一的兼容性问题就是ie6 下的BUG,但这也不困难,加上一段js处理就行了.但假如我们 ...
- c#读取通达信历史数据的方法
public Bar ReadBarMin(BinaryReader br, int instrumentId, long size) { int date = br.ReadUInt16(); in ...
- 高性能IO设计模式之阻塞/非阻塞,同步/异步解析
提到高性能,我想大家都喜欢这个,今天我们就主要来弄明白在高性能的I/O设计中的几个关键概念,做任何事最重要的第一步就是要把概念弄的清晰无误不是么?在这里就是:阻塞,非阻塞,同步,异步. OK, 现在来 ...
- C语言的printf输出格式控制
C语言的printf输出格式控制 printf大家都耳熟能详,但是能真正将其用法弄透的估计很少见. 转一篇,改天整理. 1.转换说明符 %a(%A) 浮点数.十六进制数字和p-(P-)记数法( ...
- javascript知识图谱