【USACO14FEB】洛谷2176 Roadblock

76 篇文章 0 订阅

题目描述

每天早晨,FJ从家中穿过农场走到牛棚。农场由 N 块农田组成,农田通过 M 条双向道路连接,每条路有一定长度。FJ 的房子在 1
号田,牛棚在 N
号田。没有两块田被多条道路连接,以适当的路径顺序总是能在农场任意一对田间行走。当FZ从一块田走到另一块时,总是以总路长最短的道路顺序来走。

FJ 的牛呢,总是不安好心,决定干扰他每天早晨的计划。它们在 M
条路的某一条上安放一叠稻草堆,使这条路的长度加倍。牛希望选择一条路干扰使得FJ
从家到牛棚的路长增加最多。它们请你设计并告诉它们最大增量是多少。 输入输出格式 输入格式:

第 1 行:两个整数 N, M。

第 2 到 M+1 行:第 i+1 行包含三个整数 A_i, B_i, L_i,A_i 和 B_i 表示道路 i 连接的田的编号,L_i
表示路长。

输出格式:

第 1 行:一个整数,表示通过使某条路加倍而得到的最大增量。

先跑一遍最短路,记下每个点的前驱,然后依次尝试修改路径上的每条边,计算出新的最短路。

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int oo=0x3f3f3f3f;
int fir[110],ne[10010],to[10010],len[10010],pre_v[110],pre_e[110],m,n,que[10010],dis[110];
bool modi;
void add(int num,int f,int t,int l)
{
    ne[num]=fir[f];
    fir[f]=num;
    to[num]=t;
    len[num]=l;
}
int spfa()
{
    int i,j,k,u,v,hd=1,tl=1;
    for (i=2;i<=n;i++)
      dis[i]=oo;
    dis[1]=0;
    que[1]=1;
    while (hd<=tl)
    {
        u=que[hd++];
        for (i=fir[u];i;i=ne[i])
        {
            v=to[i];
            if (dis[u]+len[i]<dis[v])
            {
                if (modi)
                {
                    pre_e[v]=i;
                    pre_v[v]=u;
                }
                dis[v]=dis[u]+len[i];
                que[++tl]=v;
            }
        }
    }
    return dis[n];
}
int main()
{
    int i,j,k,p,q,x,y,z,now,tem,ans=-1;
    scanf("%d%d",&n,&m);
    for (i=1;i<=m;i++)
    {
        scanf("%d%d%d",&x,&y,&z);
        add(i*2,x,y,z);
        add(i*2+1,y,x,z);
    }
    modi=1;
    now=spfa();
    modi=0;
    for (p=n;p!=1;p=pre_v[p])
    {
        len[pre_e[p]]*=2;
        len[pre_e[p]^1]*=2;
        tem=spfa();
        ans=max(ans,tem-now);
        len[pre_e[p]]/=2;
        len[pre_e[p]^1]/=2;
    }
    printf("%d\n",ans);
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值