LightOj 1074 Extended Traffic (spfa+负权环)
题目链接:
http://lightoj.com/volume_showproblem.php?problem=1074
题目大意:
有一个大城市有n个十字交叉口,有m条路,城市十分拥挤,因此每一个路都有一个拥挤度,政府就出台了一个政策,对每一条路收取过路费,收取标准为(终点拥挤度 - 起点拥挤度 )3,,问每次询问m,输出1到m的最小花费,如果不能到达或者最小化费小于3的时候输出‘?’。
解题思路:
用spfa。标记负环。
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std; #define maxn 210
#define INF 0x3f3f3f3f struct Edge
{
int e, w;
Edge(int e=, int w=):e(e),w(w){}
}; vector<Edge>G[maxn];
int dist[maxn], n;
bool Cin[maxn];
void init();
int spfa ();
void dfs (int u); int main ()
{
int m, t, l=, map[maxn];
scanf ("%d", &t); while (t --)
{
printf ("Case %d:\n", ++l);
init ();
scanf ("%d", &n); for (int i=; i<=n; i++)
scanf ("%d", &map[i]); scanf ("%d", &m);
while (m --)
{
int a, b, num;
scanf ("%d %d", &b, &a);
num = (map[a] - map[b]) * (map[a] - map[b]) * (map[a] - map[b]);
G[b].push_back (Edge(a, num));
}
spfa ();
scanf ("%d", &m);
while (m --)
{
int num;
scanf ("%d", &num);
if (Cin[num] || dist[num] < || dist[num] == INF)
printf ("?\n");
else
printf ("%d\n", dist[num]);
}
}
}
void init()
{
int i, j;
memset (Cin, false, sizeof(Cin));
for (i=; i<maxn; i++)
{
G[i].clear();
dist[i] = INF;
}
} int spfa ()
{
queue<int>Q;
bool vis[maxn];
int cnt[maxn];
memset (vis, false, sizeof(vis));
memset (cnt, , sizeof(cnt));
Q.push ();
cnt[] = ;
dist[] = ; while (!Q.empty())
{
int s = Q.front ();
Q.pop ();
vis[s] = false;
int len = G[s].size(); for (int i=; i<len; i++)
{
Edge x = G[s][i];
if (Cin[x.e])
continue;
if (dist[x.e] > dist[s] + x.w)
{
dist[x.e] = dist[s] + x.w;
if (!vis[x.e])
{
vis[x.e] = true;
Q.push (x.e);
cnt[x.e] ++;
if (cnt[x.e] == n)//只要x.e在负环内,则在负环内的点可以到达的点,都没有最短路径
dfs(x.e);
}
}
}
}
} void dfs (int u)
{
int len = G[u].size();
Cin[u] = true;
for (int i=; i<len; i++)//u后面的点都没有最短回路,都应该标记 {
if (!Cin[G[u][i].e])
dfs (G[u][i].e);
}
}
LightOj 1074 Extended Traffic (spfa+负权环)的更多相关文章
- LightOJ - 1074 Extended Traffic (SPFA+负环)
题意:N个点,分别有属于自己的N个busyness(简称b),两点间若有边,则边权为(ub-vb)^3.Q个查询,问从点1到该点的距离为多少. 分析:既然是差的三次方,那么可能有负边权的存在,自然有可 ...
- LightOJ 1074 Extended Traffic SPFA 消负环
分析:一看就是求最短路,然后用dij,果断错了一发,发现是3次方,有可能会出现负环 然后用spfa判负环,然后标记负环所有可达的点,被标记的点答案都是“?” #include<cstdio> ...
- LightOJ 1074 Extended Traffic(spfa+dfs标记负环上的点)
题目链接:https://cn.vjudge.net/contest/189021#problem/O 题目大意:有n个站点,每个站点都有一个busyness,从站点A到站点B的花费为(busynes ...
- LightOJ 1074 - Extended Traffic (SPFA)
http://lightoj.com/volume_showproblem.php?problem=1074 1074 - Extended Traffic PDF (English) Stati ...
- LightOJ 1074 Extended Traffic (最短路spfa+标记负环点)
Extended Traffic 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/O Description Dhaka city ...
- lightoj 1074 - Extended Traffic(spfa+负环判断)
题目链接:http://www.lightoj.com/volume_showproblem.php?problem=1074 题意:有n个城市,每一个城市有一个拥挤度ai,从一个城市I到另一个城市J ...
- SPFA(负环) LightOJ 1074 Extended Traffic
题目传送门 题意:收过路费.如果最后的收费小于3或不能达到,输出'?'.否则输出到n点最小的过路费 分析:关键权值可为负,如果碰到负环是,小于3的约束条件不够,那么在得知有负环时,把这个环的点都标记下 ...
- (简单) LightOJ 1074 Extended Traffic,SPFA+负环。
Description Dhaka city is getting crowded and noisy day by day. Certain roads always remain blocked ...
- LightOJ - 1074 Extended Traffic(标记负环)
题意:有n个城市,每一个城市有一个拥挤度ai,从一个城市u到另一个城市v的时间为:(au-av)^3,存在负环.问从第一个城市到达第k个城市所话的时间,如果不能到达,或者时间小于3输出?否则输出所花的 ...
随机推荐
- HDU 4115 Eliminate the Conflict(2-sat)
HDU 4115 Eliminate the Conflict pid=4115">题目链接 题意:Alice和Bob这对狗男女在玩剪刀石头布.已知Bob每轮要出什么,然后Bob给Al ...
- CentOS7 设置系统时间
在CentOS 6版本,时间设置有date.hwclock命令, 硬件时钟和系统时钟 (1) 硬件时钟 RTC(Real-Time Clock)或CMOS时钟,一般在主板上靠电池供电,服务器断电后也会 ...
- 阅读《Android 从入门到精通》(33)——Intent 分类
Intent 分类 显式 Intent:Intent("android.intent.action.CALL", Uri.parse("tel:" + stri ...
- Deepin-键盘快捷键
是不是很happy呢? 可以用键盘替代鼠标点点点了! 1.鼠标移到右下角 2.下翻找到"快捷键" 3.自定义一个 4.示例(首先编写个简单的Shell) 程序一般放在/usr/bi ...
- APache POI emaple ()
Business Plan The BusinessPlan application creates a sample business plan with three phases, weekly ...
- 关于mybatis的 insert into select 命令未结束问题
关于mybatis的 insert into select 命令未结束问题,最后以为是sql写错了,可是,在plsql运行又没问题.最后还是解决这个问题. 是设置问题. ### Cause: java ...
- BZOJ 2460: [BeiJing2011]元素 线性基
2460: [BeiJing2011]元素 Description 相传,在远古时期,位于西方大陆的 Magic Land 上,人们已经掌握了用魔法矿石炼制法杖的技术.那时人们就认识到,一个法杖的法力 ...
- The android gradle plugin version 2.3.0-beta2 is too old, please update to the latest version.
编译项目的时候,报如下错误: Error:(, ) A problem occurred evaluating project ':app'. > Failed to apply plugin ...
- 网络驱动移植之net_device结构体及其相关的操作函数
内核源码:Linux-2.6.38.8.tar.bz2 在Linux系统中,网络设备都被抽象为struct net_device结构体.它是网络设备硬件与上层协议之间联系的接口,了解它对编写网络驱动程 ...
- sabaki and leelazero
https://tieba.baidu.com/p/5462772621?see_lz=1 http://zero.sjeng.org/ https://www.jianshu.com/p/a4ba1 ...