差分约束系统

43 篇文章 0 订阅
39 篇文章 6 订阅

好吧,其实很好理解

对于一些不等式
s[x1]-s[y1]>=a1
s[x2]-s[y2]>=a2
……

它们的解是什么呢?
首先可以将每个y向x连边
那么
从y能够更新走到x的最短路必须满足
s[x]>s[y]+a
移项
s[x]s[y]>a
你发现了什么?
又变回了不等式!!
这就是差分约束系统
对于整个不等式组的解就是从1到n的最短路
当然,在某些题目中也有可能是求最长路
用一个spfa就行了
在一些题目中稍加转化,注意好隐含条件,就可以用差分约束搞定

        int i=0,j=1,bz[N];dd[1]=0;
        memset(s,128,sizeof(s));s[0]=0;memset(bz,0,sizeof(bz));bz[0]=1;
        for(;i<j;)
        {
            int x=dd[++i];
            for(int k=last[x];k;k=next[k])
            {
                if (s[to[k]]<s[x]+data[k])
                {
                    s[to[k]]=s[x]+data[k];
                    if (bz[to[k]]==0)
                    {
                        dd[++j]=to[k];bz[to[k]]=1;
                    }
                }   
            }
            bz[x]=0;
        }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值