隐藏页面特效

[差分约束]

1|0差分约束


1|1定义


差分约束系统 是一种特殊的n元一次不等式组,它包含n个变量x1,x2,,xn 以及m个约束条件,每个约束条件是由两个其中的变量做差构成的,形如xixjCk或者xixjCk其中1i,jn1km

1|2做法


假如有式子

{x1x2C1x2x3C2x1x3C3

我们发现由前两个式子相加可以得到x1x3C1+C2,和第三个式子对比发现,如果要满足这三个式子,那么x1x3应该在C1+C2C3中取一个最小值,那么此时就会发现这个结构跟最短路的三角形不等式相似,如果将作差比作一条路径的话那么就是dis[1][2]+dis[2][3]dis[1][3]min,同理xixjCk的时候应该取max

那么定义fmax[i][j]xixj的最大值,fmin[i][j]xixj的最小值,当xixjCk可以给fmax[i][j]赋值为Ck,当xixjCkfmin[i][j]赋值为Ck,但是更新的时候要给fmaxmin,给fminmax,原理就是上面的式子

知道了原理之后,剩下的就是跑最短路/最长路了

例题洛谷P2474

#include <cstdio> #include <cstring> #include <iostream> using namespace std; int n,A,B; char s[55]; int fmin[55][55],fmax[55][55]; int main() { memset(fmax,127,sizeof(fmax)); scanf("%d%d%d",&n,&A,&B); for(int i=1;i<=n;i++) { scanf("%s",s+1); int l = strlen(s+1); for(int j=1;j<=l;j++) { if(s[j] == '=' || i == j) { fmin[i][j] = fmax[i][j] = 0; } else if(s[j] == '+') { fmin[i][j] = 1; fmax[i][j] = 2; } else if(s[j] == '-') { fmin[i][j] = -2; fmax[i][j] = -1; } else if(s[j] == '?') { fmin[i][j] = -2; fmax[i][j] = 2; } } getchar(); } for(int k=1;k<=n;k++) for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) { fmin[i][j] = max(fmin[i][j],fmin[i][k]+fmin[k][j]); fmax[i][j] = min(fmax[i][j],fmax[i][k]+fmax[k][j]); } int c1 = 0,c2 = 0,c3 = 0; for(int i=1;i<n;i++) for(int j=i+1;j<=n;j++) { if(A == i || A == j || B == i || B == j) continue; if(fmax[A][i] < fmin[j][B] || fmax[A][j] < fmin[i][B]) c3 ++; else if(fmax[A][i] == fmin[A][i] && fmax[j][B] == fmin[j][B] && fmax[A][i] == fmax[j][B]) c2 ++; else if(fmax[A][j] == fmin[A][j] && fmax[i][B] == fmin[i][B] && fmax[A][j] == fmax[i][B]) c2 ++; else if(fmin[A][i] > fmax[j][B] || fmin[A][j] > fmax[i][B]) c1 ++; } printf("%d %d %d",c1,c2,c3); return 0; }

__EOF__

本文作者风丨铃
本文链接https://www.cnblogs.com/-Wind-/p/18307583.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   风丨铃  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
点击右上角即可分享
微信分享提示