HDU 1317 XYZZY Bellman-Ford求最长路 判断正环
来源:互联网 发布:unity3d开发安卓游戏 编辑:程序博客网 时间:2024/06/13 09:06
题意:给你n个房间 开始有能量值100 判断能否从1到第n个房间
每到一个房间可以获得能量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[n]);if(dis[n] > 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][n])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");elseputs("hopeless");}return 0;}
0 0
- HDU 1317 XYZZY Bellman-Ford求最长路 判断正环
- hdu-1317-XYZZY-Bellman-Ford判环、Floyd算法
- POJ 1860 Currency Exchange(Bellman-Ford判断最长路是否含有正环)
- HDU 1317 XYZZY Floyd判断能否到达+SPFA判断能否形成环及求最长路(好题)
- hdoj1317-XYZZY(bellman-ford)
- 【bellman-Ford判断正权回路】POJ
- HDU 1317--XYZZY 【spfa判断正环求最长路径 && floyd求传递闭包】
- HDU 1317 Bellman-Ford
- 10557 - XYZZY(****)---Bellman-Ford算法
- HDU:1317 XYZZY(SPFA处理正环+Flody判断点连通)
- HDU 1317 POJ 1932 XYZZY 正负环+最长路
- [HDU 1317]XYZZY[SPFA变形][最长路]
- HDU - 1317 XYZZY (floyd + 最长路)
- hdu 1317 XYZZY(bellman + Floyed)
- hdu 1317 XYZZY(bellman_ford判断环,有负权)
- hdu 1317 XYZZY spfa判断负环
- hdu 1317 floyd+bellman-Ford
- hdu1317—XYZZY(floyed+Bellman-Ford)
- 如何快速取得一个二进制状态的所有子状态
- forward与redirect的区别
- XCode5添加新建类模板(Cocos2dx Template Class for Scene or Layer)
- ubuntu 12.04 进不了图形界面的修复
- spring+ibatis框架下事务代码的编写示例
- HDU 1317 XYZZY Bellman-Ford求最长路 判断正环
- C语言格式输出函数printf()详解
- Android开发学习笔记4--安卓程序安装与启动过程剖析
- PHP 5.3.6及以前版本的PDO的bindParam,bindValue潜在的安全隐患
- Day12 - usermod 修改用户帐号
- 怎样清空输入缓冲区里的内容
- LA6142 Probability Through Experiments 统计圆上的锐角三角形
- Android开发学习笔记6--安卓程序调试方法
- linux环境禁用apache目录浏览功能