ACM/ICPC 之 DFS+SPFA-贪心+最短路(POJ2679)
//POJ2679
//DFS+SPFA+邻接表
//只能走每个点费用最小的边,相同则需保证距离最短
//求最小费用及最短距离
//Time:47Ms Memory:900K
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std; #define MAXN 1105
#define MAXM 5005
#define INF 0x3f3f3f3f struct Edge{
int v,len,fee,next;
Edge(){}
Edge(int vv,int ll,int ff, int nn):v(vv),len(ll),fee(ff),next(nn){}
}e[2*MAXM]; int n,m;
int dept,dest;
int h[MAXN], le;
int minfee[MAXN], minFee[MAXN];
int vis[MAXN];
int d[MAXN], cnt[MAXN]; void add(int u, int v,int w,int fuv,int fvu)
{
e[le] = Edge(v, w, fuv, h[u]); h[u] = le++;
e[le] = Edge(u, w, fvu, h[v]); h[v] = le++;
} bool dfs(int x) //判定从x是否可达终点
{
vis[x] = true;
if(x == dest) return true;
if(minfee[x] == INF) return false;
for(int i = h[x]; i != -1; i = e[i].next)
{
if(!vis[e[i].v] && minfee[x] == e[i].fee){
if(dfs(e[i].v)) return true;
vis[e[i].v] = false;
}
}
return false;
} bool spfa(int x)
{
memset(d,INF,sizeof(d));
memset(vis,false,sizeof(vis));
memset(cnt, 0, sizeof(cnt));
memset(minFee, 0, sizeof(minFee));
queue<int> q;
q.push(x); vis[x] = true;
cnt[x] = 1; d[x] = 0; minFee[x] = 0;
while(!q.empty()){
int cur = q.front();
q.pop(); vis[cur] = false;
for(int i = h[cur]; i != -1; i = e[i].next)
{
if(minfee[cur] != e[i].fee) continue;
int v = e[i].v, w = e[i].len;
if(minFee[v] > minFee[cur] + minfee[cur] ||
d[v] > d[cur] + w) //先判断费用更小,再判断距离更小
{
minFee[v] = minFee[cur] + minfee[cur];
d[v] = d[cur] + w;
if(!vis[v]){
vis[v] = true;
if(++cnt[v] > n) //成环
{
if(dfs(v)) return false; //可达终点
else continue; //不可达终点
}
q.push(v);
}
}
}
}
return true;
} int main()
{
//freopen("in.txt", "r", stdin); while(~scanf("%d%d%d%d", &n,&m,&dept,&dest))
{
memset(h,-1,sizeof(h));
memset(minfee,INF,sizeof(minfee));
le = 0;
char cmd[100];
int u,v,w,fuv,fvu;
for(int i = 0; i < m; i++)
{
scanf("%s", cmd);
sscanf(cmd, "(%d,%d,%d[%d]%d)", &u,&v,&fuv,&w,&fvu);
add(u,v,w,fuv,fvu);
minfee[u] = min(minfee[u], fuv);
minfee[v] = min(minfee[v], fvu);
} memset(vis,false,sizeof(vis));
bool VOID = !dfs(dept);
if(VOID){ //没有路径可达
printf("VOID\n");
continue;
}
bool UNBOUND = !spfa(dept); //可达路径中存在负权费用环路
if(UNBOUND) printf("UNBOUND\n");
else printf("%d %d\n", minFee[dest], d[dest]);
} return 0;
}
ACM/ICPC 之 DFS+SPFA-贪心+最短路(POJ2679)的更多相关文章
- 2017 ACM/ICPC Shenyang Online SPFA+无向图最长路
transaction transaction transaction Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 132768/1 ...
- ACM/ICPC 之 DFS求解欧拉通路路径(POJ2337)
判断是欧拉通路后,DFS简单剪枝求解字典序最小的欧拉通路路径 //Time:16Ms Memory:228K #include<iostream> #include<cstring& ...
- ACM/ICPC 之 DFS求解欧拉回路+打表(POJ1392)
本题可以通过全部n位二进制数作点,而后可按照某点A的末位数与某点B的首位数相等来建立A->B有向边,以此构图,改有向图则是一个有向欧拉回路,以下我利用DFS暴力求解该欧拉回路得到的字典序最小的路 ...
- ACM/ICPC 之 昂贵的聘礼-最短路解法(POJ1062)
//转移为最短路问题,枚举必经每一个不小于酋长等级的人的最短路 //Time:16Ms Memory:208K #include<iostream> #include<cstring ...
- ACM/ICPC 之 DFS范例(ZOJ2412-ZOJ1008)
通过几道例题简单阐述一下DFS的相关题型 ZOJ2412-Farm Irrigation 直观的DFS题型,稍加变化,记录好四个方向上的通路就能够做出来 题目和接水管类似,问最少要灌溉几次,即求解最少 ...
- HDU 5876 Sparse Graph 【补图最短路 BFS】(2016 ACM/ICPC Asia Regional Dalian Online)
Sparse Graph Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)To ...
- 2017 ACM/ICPC Asia Regional Shenyang Online spfa+最长路
transaction transaction transaction Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 132768/1 ...
- ACM - 最短路 - AcWing 851 spfa求最短路
AcWing 851 spfa求最短路 题解 以此题为例介绍一下图论中的最短路算法 \(Bellman\)-\(Ford\) 算法.算法的步骤和正确性证明参考文章最短路径(Bellman-Ford算法 ...
- hdu 5016 点分治(2014 ACM/ICPC Asia Regional Xi'an Online)
Mart Master II Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
随机推荐
- jQuery之核心API
1. jQuery.holdReady()方法:暂停或恢复.ready() 事件的执行.在$.holdReady()方法允许调用者延迟jQuery的ready事件.这种先进的功能,通常会被用来允许在 ...
- C程序设计语言学习笔记
在Windows下运行C语言程序 Windows下的编程工具使用 VC 6.0,下面讲解如何在VC 6.0下运行上节的"Hello, world"程序. 1) 新建Win32 Co ...
- C++ namespace
namespace, 命名空间, 用于解决命名冲突的问题. Python中的package/module, Javascript中的object, Java中的package都具有这样的功能. 如何使 ...
- CSS选 择器 三种样式
一.CSS三种样式 代码 宽度 高度 实线 颜色 A内联样式是优先级最高的方式 px必须写 A:内联式 弊端:代码多很乱 <body> <div class="divc ...
- jquery $.extend()扩展插件获取焦点或失去焦点事件
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- POJ Minimum Cut
Minimum Cut Time Limit: 10000MS Memory Limit: 65536K Total Submissions: 9302 Accepted: 3902 Case ...
- java面向对象---对象初始化
在本地变量中,如果定义了一个变量后没有赋值就使用,那么eclipse就会报错:但是在成员变量中,java是会强制给一个没有初始化的变量一个默认的初始值0, 如果是一个boolean类型的变量,那么默认 ...
- json数组去重
//名字去重 Map<String,Integer> map=new HashMap<String,Integer>(); for(int i=0;i<jows.size ...
- Android File存储
原创文章,转载请注明出处:http://www.cnblogs.com/baipengzhan/p/Android_File_store.html 一 概念 Android系统中提供了一种文件读写的方 ...
- Collection集合的功能及总结
Collection集合是集合顶层接口,不能实例化 功能 1.添加功能 boolean add(Object obj):添加一个元素 boolean addAll(Collection c):添加一个 ...