标签:des style blog http color 使用 os io
| Time Limit: 1000MS | Memory Limit: 30000K | |
| Total Submissions: 19881 | Accepted: 7114 | 
Description
Input
Output
Sample Input
3 2 1 20.0
1 2 1.00 1.00 1.00 1.00
2 3 1.10 1.00 1.10 1.00
Sample Output
YES
Source
Mean:
你有一些古币,现在你要用这些古币去兑换成其他钱币。这个城市里有N个兑换点,每个兑换点包括:
A----钱币A
B----钱币B
Rab--A兑换为B的比例
Cab--A兑换为B的手续费
Rba--B兑换为A的比例
Cba--B兑换为A的手续费
现在你有编号为S的这种古币,你将用这些古币去进行一系列的兑换,最终还是要兑换回古币。你想知道能不能通过一系列兑换来增加自身的古币。
N--钱币的种类总数(结点数)
M--兑换点的数量(边的条数)
S--你的货币种类标识(起点&终点)
V--你现在身上货币的数目
analyse:
判断图中是否存在正权回路。
使用spfa来不断迭代求最大路径,如果这个过程中某个点的迭代次数超过了n次,那么一定存在正权回路。
其实一般情况下每个点的迭代次数不会超过2,所以这题把n改为3也能过,当然如果存在正权回路的话一定会超过n,所以在不卡时间的情况下,就用n来判断保险一点。
Time complexity:O(m*k),k为每个点平均迭代次数
Source code:
//Memory   Time
//  164K     0MS
// by : Snarl_jsb
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<vector>
#include<queue>
#include<stack>
#include<iomanip>
#include<string>
#include<climits>
#include<cmath>
#define MAXV 110
#define MAXE 110<<1
#define LL long long
using namespace std;
int n,m,sta;
float num;
int vis[MAXV];
float dis[MAXV];
int cnt[MAXV];
namespace Adj
{
    struct Edge
    {
        int to,next;
        float rate,cost;
    };
    Edge edge[MAXE];
    int top;
    int head[MAXV];
    void init()
    {
        top=1;
        memset(head,0,sizeof(head));
    }
    void addEdge(int u,int v,float rate,float cost)
    {
        edge[top].to=v;
        edge[top].rate=rate;
        edge[top].cost=cost;
        edge[top].next=head[u];
        head[u]=top++;
    }
}
using namespace Adj;
bool spfa()
{
    for(int i=1;i<=n;i++)
        cnt[i]=vis[i]=0,dis[i]=0.0;
    queue<int>Q;
    Q.push(sta);
    vis[sta]=1;
    dis[sta]=num;
    while(!Q.empty())
    {
        int now=Q.front();
        Q.pop();
        vis[now]=0;
        for(int i=head[now];i;i=edge[i].next)
        {
            int son=edge[i].to;
            float tmp=(dis[now]-edge[i].cost)*edge[i].rate*1.0;
            if(dis[son]<tmp)
            {
                dis[son]=tmp;
                if(!vis[son])
                {
                    Q.push(son);
                    vis[son]=1;
                }
                cnt[son]++;
                if(cnt[son]>3)  //   某个结点迭代次数超过了n次,存在正权回路
                    return false;
            }
        }
    }
    return true;
}
int main()
{
//    freopen("cin.txt","r",stdin);
//    freopen("cout.txt","w",stdout);
    scanf("%d %d %d %f",&n,&m,&sta,&num);
    Adj:: init();
    int a,b;
    float r1,c1,r2,c2;
    while(m--)
    {
        scanf("%d %d %f %f %f %f",&a,&b,&r1,&c1,&r2,&c2);
        Adj:: addEdge(a,b,r1,c1);
        Adj:: addEdge(b,a,r2,c2);
    }
    if(!spfa())
        puts("YES");
    else
        puts("NO");
    return 0;
}
图论 --- spfa + 链式向前星 : 判断是否存在正权回路 poj 1860 : Currency Exchange,布布扣,bubuko.com
图论 --- spfa + 链式向前星 : 判断是否存在正权回路 poj 1860 : Currency Exchange
标签:des style blog http color 使用 os io
原文地址:http://www.cnblogs.com/acmer-jsb/p/3899868.html