HDU 1317 XYZZY Bellman-Ford求最长路 判断正环
2014-04-04 18:50
246 查看
题意:给你n个房间 开始有能量值100 判断能否从1到第n个房间
每到一个房间可以获得能量x(可能小于0) 每到一个房间总能量必须大于0 每个房间可以重复到达
思路:求一个从1到n的最长路 不过可能有正环 没有正环 直接求最长路 如果有正环 判断环中的点是否可以到达n
具体用Bellman-Ford算法 虽然复杂度是(n*m)这题应该可以了 如果迭代n-1次之后还能松弛 说明有正环 然后用floyd判断是否可达
每到一个房间可以获得能量x(可能小于0) 每到一个房间总能量必须大于0 每个房间可以重复到达
思路:求一个从1到n的最长路 不过可能有正环 没有正环 直接求最长路 如果有正环 判断环中的点是否可以到达n
具体用Bellman-Ford算法 虽然复杂度是(n*m)这题应该可以了 如果迭代n-1次之后还能松弛 说明有正环 然后用floyd判断是否可达
#include <cstdio> #include <algorithm> #include <queue> #include <vector> using namespace std; const int maxn = 110; struct edge { int u, v, w; }; vector <edge> G; int dis[maxn]; bool vis[maxn]; int n, m; int a[maxn][maxn]; void floyd() { for(int k = 1; k <= n; k++) for(int i = 1; i <= n; i++) for(int j = 1; j <= n; j++) a[i][j] = a[i][j] || (a[i][k] && a[k][j]); } bool Bellman_Ford() { for(int i = 1; i <= n; i++) dis[i] = -999999999; dis[1] = 100; for(int i = 1; i < n; i++) { for(int j = 0; j < G.size(); j++) { edge e = G[j]; if(dis[e.v] < dis[e.u] + e.w && dis[e.u] + e.w > 0) dis[e.v] = dis[e.u] + e.w; } } //printf("%d\n", dis ); if(dis > 0) return true; for(int i = 0; i < G.size(); i++) { edge e = G[i]; if(dis[e.v] < dis[e.u] + e.w && dis[e.u] + e.w > 0) { //puts("sss"); dis[e.v] = dis[e.u] + e.w; if(a[e.v] ) return true; } } return false; } int main() { while(scanf("%d", &n) && n != -1) { //for(int i = 0; i <= n; i++) G.clear(); memset(a, 0, sizeof(a)); for(int i = 1; i <= n; i++) { int t, v, w; scanf("%d %d", &w, &t); while(t--) { scanf("%d", &v); G.push_back((edge){i, v, w}); //G.push_back((edge){v, i, w}); a[i][v] = 1; //a[v][i] = 1; //G[v].push_back((edge){u, w}); } } floyd(); if(Bellman_Ford()) puts("winnable"); else puts("hopeless"); } return 0; }
相关文章推荐
- HDU 1317 XYZZY【Bellman_Ford判断正环】
- hdu 1317 XYZZY【Bellheman_ford 判断正环小应用】
- hdu 1317 XYZZY【Bellheman_ford 判断正环小应用】
- hdu 1317 XYZZY【Bellheman_ford 判断正环小应用】
- hdu 1317 SPFA+连通判断+最长路
- hdu 1317 XYZZY(bellman_ford判断环,有负权)
- HDU 1317--XYZZY 【spfa判断正环求最长路径 && floyd求传递闭包】
- [HDU 1317]XYZZY[SPFA变形][最长路]
- HDU 1317 POJ 1932 XYZZY 正负环+最长路
- hdu 1317 spfa判环求最长路
- HDU 1317(Floyd判断连通性+spfa判断正环)
- HDU 1317 Bellman-Ford
- HDU 1317 XYZZY Floyd判断能否到达+SPFA判断能否形成环及求最长路(好题)
- HDU-1317-XYZZY(负权处理 弗洛伊德判断连通性)
- (floyd 1.1)hdu 1217 Arbitrage(使用floyd来求最长路——判断是否存在一种货币,经过一个兑换回路以后>=1单元)
- HDU:1317 XYZZY(SPFA处理正环+Flody判断点连通)
- hdu-1317-XYZZY-Bellman-Ford判环、Floyd算法
- HDU 1317 XYZZ(Floyd(传递闭包)+bellmanfd(判断正权环))
- hdu 1317 floyd+bellman-Ford
- hdu 1317 XYZZY spfa判断负环