码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 3621 Sightseeing Cows | 01分数规划

时间:2018-01-10 11:49:45      阅读:123      评论:0      收藏:0      [点我收藏+]

标签:fine   ret   +=   else   log   dfs   ble   题解   using   

题目:

http://poj.org/problem?id=3621


题解:

二分答案,检查有没有负环

#include<cstdio>
#include<algorithm>
#include<cstring>
#define N 1005
using namespace std;
struct node
{
    int nxt,v;
    double w;
}e[N*5];
int head[N],ecnt,L,P;
double dis[N],fun[N],l,r,mid;
bool vis[N];
void add(int u,int v,int w)
{
    e[++ecnt].v=v;e[ecnt].w=w;e[ecnt].nxt=head[u];head[u]=ecnt;
}
bool spfa_dfs(int u,double val)
{
    vis[u]=1;
    for (int i=head[u],v;i;i=e[i].nxt)
    {
    if (dis[v=e[i].v]>dis[u]+e[i].w*val-fun[u])
    {
        dis[v]=dis[u]+e[i].w*val-fun[u];
        if (!vis[v]) {if (spfa_dfs(v,val)) return 1;}
        else return 1;
     }
    }
    vis[u]=0;
    return 0;
}
bool check(double mid)
{
    memset(vis,0,sizeof(vis));
    memset(dis,0,sizeof(dis));
    for (int i=1;i<=L;i++)
    if (spfa_dfs(i,mid)) return 1;
    return 0;
}
int main()
{
    scanf("%d%d",&L,&P);
    for (int i=1;i<=L;i++)
    scanf("%lf",&fun[i]),r+=fun[i];
    for (int i=1,u,v,c;i<=P;i++)
    scanf("%d%d%d",&u,&v,&c),add(u,v,c);
    for (int i=1;i<=50;i++)
    {
    mid=(l+r)/2.0;
    if (check(mid)) l=mid;
    else r=mid;
    }
    printf("%.2f\n",l);
    return 0;
}

 

POJ 3621 Sightseeing Cows | 01分数规划

标签:fine   ret   +=   else   log   dfs   ble   题解   using   

原文地址:https://www.cnblogs.com/mrsheep/p/8256791.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!