UVA 11090 : Going in Cycle!! 【spfa】
题意及题解参见lrj训练指南
#include<bits/stdc++.h>
using namespace std; const double INF=1e18;
const int maxn=;
const int maxm=; int n,m;
struct Edge
{
int to,next;
double d;
Edge(){}
Edge(int to_,int next_,double d_)
{
to=to_,next=next_,d=d_;
}
};
Edge edge[maxm];
int head[maxn],tot;
bool inq[maxn];
double d[maxn];
int p[maxn];
int cnt[maxn]; void init()
{
memset(head,-,sizeof(head));
tot=;
}
void addedge(int u,int v,double d)
{
edge[tot]=Edge(v,head[u],d);
head[u]=tot++;
} // 顶点编号0~n-1共n个点
// 返回值表示 从s出发,能否遇到负环
bool spfa(int s,int n)
{
queue<int> Q;
for(int i=;i<n;i++) d[i]=INF;
memset(inq,false,sizeof(inq));
memset(cnt,,sizeof(cnt));
Q.push(s),inq[s]=true,d[s]=;
while(!Q.empty())
{
int u=Q.front();Q.pop();
inq[u]=false;
for(int i=head[u];~i;i=edge[i].next)
{
Edge& e=edge[i];
if(d[e.to]>d[u]+e.d)
{
d[e.to]=d[u]+e.d;
p[e.to]=i;
if(!inq[e.to])
{
Q.push(e.to),inq[e.to]=true;
if(++cnt[e.to]>=n) return true;//存在负环
}
}
}
}
return false; //无负环
} bool ok(double x)
{
for(int i=;i<tot;i++) edge[i].d-=x;
bool ret=spfa(,n+);
for(int i=;i<tot;i++) edge[i].d+=x;
return ret;
} int main()
{
int T,kase=;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&m);
init();
double ud=;
while(m--)
{
int u,v;
double d;
scanf("%d%d%lf",&u,&v,&d);
addedge(u,v,d);
ud=max(ud,d);
}
for(int i=;i<=n;i++) addedge(,i,ud+);
printf("Case #%d: ",++kase);
if(!ok(ud+))
{
puts("No cycle found.");
continue;
}
double l=,r=ud;
while(r-l>1e-)
{
double mid=(l+r)/;
if(ok(mid)) r=mid;
else l=mid;
}
printf("%.2lf\n",l);
}
}
UVA 11090 : Going in Cycle!! 【spfa】的更多相关文章
- UVa 11090 Going in Cycle!!【Bellman_Ford】
题意:给出n个点m条边的加权有向图,求平均值最小的回路 自己想的是用DFS找环(真是too young),在比较找到各个环的平均权值,可是代码实现不了,觉得又不太对 后来看书= =好巧妙的办法, 使用 ...
- UVA11090 Going in Cycle!! 【SPFA】
题意:求一个无向图的边权平均值最小的环 思路:假设环中Σwi/t<ans 那变形一下就是Σwi<ans*t → Σ(wi-ans)< 0 这样就可以二分答案做了 #include & ...
- UVA - 11090 - Going in Cycle!!(二分+差分约束系统)
Problem UVA - 11090 - Going in Cycle!! Time Limit: 3000 mSec Problem Description You are given a we ...
- UVA 11090 - Going in Cycle!!(Bellman-Ford)
UVA 11090 - Going in Cycle!! option=com_onlinejudge&Itemid=8&page=show_problem&category= ...
- 141. Linked List Cycle【easy】
141. Linked List Cycle[easy] Given a linked list, determine if it has a cycle in it. Follow up:Can y ...
- 【SPFA】 最短路计数
最短路计数 [问题描述] 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. [输入格式] 输入第一行包含2个正整数N,M,为图的顶点数与边数. ...
- sendrose【SPFA】
之前看到一题需要并查集+SPFA,然后就特别囧的发现自己SPFA这个历史遗留问题已经不知道怎么打了╮(╯▽╰)╭ 就果断挑了一题特别裸的SPFA赶紧搞搞掉,顺便自己乱YY下学SPFA的笔记,免得自己下 ...
- uva 10154 - Weights and Measures【dp】qi
题意:uva 10154 - Weights and Measures 题意:有一些乌龟有一定的体重和力量,求摞起来的最大高度.力量必须承受其上面包含自己的所有的重量. 分析:先按其能举起来的力量从小 ...
- 【SPFA】POJ1511-Invitation Cards
[题目大意] 给出一张有向图,以1位源点,求“从源点出发到各点的距离”和“与各点返回源点的距离和”相加得到的和. [思路] 毫无疑问是最短路径,但是这数据量就算是SPFA也绝壁会超时啊,抱着必死的心态 ...
随机推荐
- 查询sq字段逗号分隔的方式
2,3,4 -- select * from t_qs_anlycomagingconfig twhere and ( to_char(','||t.valid_month||',') like '% ...
- lnmp 环境下 部署 laravel 项目
出现错误 Warning: require(): open_basedir restriction in effect. File(/xxxx/vendor/autoload.php) is not ...
- 原生js之addEventListener,removeEventListener
使用addEventListener添加事件 <!DOCTYPE html> <html lang="en"> <head> <meta ...
- Pytorch笔记 (3) 科学计算2
一.组织张量的元素 (1)重排张量元素 本节介绍在不改变 张量元素个数 和 各元素的值的情况下改变张量的大小 torch.Tensor类的成员方法 reshape() 参数是多个int类型的值. 如果 ...
- Pytorch笔记 (3) 科学计算1
一.张量 标量 可以看作是 零维张量 向量 可以看作是 一维张量 矩阵 可以看作是 二维张量 继续扩展数据的维度,可以得到更高维度的张量 ————> 张量又称 多维数组 给定一个张量数据 ...
- hadop-eclipse-plugin导入plugins后没有mapreduce视图
这种现象一般由于安装在eclipse\plugins下的插件没有导入的问题. 解决方法:把 eclipse\configuration\org.eclipse.update 删除掉.出现这种情况的原因 ...
- 平衡树(fhq无旋treap)
fhq板子(代码正确且风格易懂) 洛谷P3369 #include<iostream> #include<cstring> #include<cstdio> #in ...
- [Vuejs] 点击单选框触发两次点击事件的处理
<el-radio-group v-model="uploadStatus" class="upload-status-radio"> <el ...
- Object的create、assign、getPrototypeOf与拷贝
Object的create.assign.getPrototypeOf与拷贝:https://www.cnblogs.com/ninalei/p/8655567.html
- python根据文本生成词云图
python根据文本生成词云图 效果 代码 from wordcloud import WordCloud import codecs import jieba #import jieba.analy ...