当前位置: 首页 > news >正文

怎么做娱乐网站网站转应用

怎么做娱乐网站,网站转应用,wordpress使用阿里云oss存储,跨境电商服务平台有哪些前置:spfa 从例题入手: 【模板】差分约束系统 | StarryCoding 题目描述 给定 n n n未知量和一个大小为 m m m的不等式(或等式)组,请你判断这个不等式(或等式)组是否有解。 1 1 1 i i i j …

前置:spfa

从例题入手:

【模板】差分约束系统 | StarryCoding

题目描述

给定 n n n未知量和一个大小为 m m m的不等式(或等式)组,请你判断这个不等式(或等式)组是否有解。

1 1 1 i i i j j j z z z:表示 x i ≤ x j + z x_i \leq x_j + z xixj+z

2 2 2 i i i j j j z z z:表示 x i ≥ x j + z x_i \geq x_j + z xixj+z

3 3 3 i i i j j j:表示 x i = y j x_i = y_j xi=yj

若存在解,输出 Y E S YES YES

若不存在解,输出 N O NO NO

输入描述

第一行一个整数 T T T表示样例个数。 ( 1 ≤ T ≤ 1000 ) (1 \leq T \leq 1000) (1T1000)

对于每组样例:

第一行两个整数 n , m n,m n,m ( 2 ≤ n ≤ 5 × 1 0 3 , 1 ≤ m ≤ 5 × 1 0 3 ) (2 \leq n \leq 5 \times 10^3,1 \leq m \leq 5 \times 10^3) (2n5×103,1m5×103)

接下来 m m m行,每行一个不等式组。 ( 1 ≤ i , j ≤ n , 1 ≤ z ≤ 1 0 7 ) (1 \leq i,j \leq n,1 \leq z \leq 10^7) (1i,jn,1z107)

数据保证 ∑ n ≤ 5 × 1 0 3 , ∑ m ≤ 1 0 4 \sum n \leq 5 \times 10^3, \sum m \leq 10^4 n5×103,m104

输出描述

对于每组样例,第一行输出 Y E S YES YES N O NO NO

输入样例

23 3
1 1 2 3
1 1 3 3
2 1 3 43 3
1 1 2 3
1 1 3 3
2 1 3 3

输出样例

NO
YES

在我们的 s p f a spfa spfa中,当 d [ y ] > d [ x ] + w d[y] > d[x] + w d[y]>d[x]+w时,我们就会更新 d [ y ] d[y] d[y],换句话说,若存在一条边连接着点 x x x y y y,则 d [ y ] < = d [ x ] + w d[y] <= d[x] + w d[y]<=d[x]+w恒成立。而这个不等式就相当于题目中第一个不等式 x i ≤ x j + z x_i \leq x_j + z xixj+z,这也就是差分约束的原理。

所以,对于 x i ≤ x j + z x_i \leq x_j + z xixj+z,可以假定有一条权值为 z z z的边从点 j j j出发指向 i i i

那具体如何判断所给不等式组是否有解?可以拟定一个虚拟源点 0 0 0,用边权为 0 0 0的边连到所有节点。然后从这个虚拟源点出发跑一遍最短路,若出现负环,则不等式组无解,因为出现负环时, 0 0 0 i i i的距离比 0 0 0 j j j的距离更远,用公式来讲就是 d [ i ] > d [ j ] + z d[i] > d[j] + z d[i]>d[j]+z x i > x j + z x_i > x_j + z xi>xj+z,不符合题意。

对于第二个不等式 x i ≥ x j + z x_i \geq x_j + z xixj+z则变形为, x j ≤ x i − z x_j \leq x_i - z xjxiz

对于第三个式子 x i = y j x_i = y_j xi=yj,则在 x x x y y y之间建立一个边权为 0 0 0的双向边。

#include<bits/stdc++.h>
using namespace std;
const int N = 2e5 + 9;
using ll = long long;
const ll inf = 2e18;struct Edge
{int x;ll w;
};int n, m;
vector<Edge> g[N];
ll d[N];bool spfa(int st)
{//两行初始化,不要忘记for(int i = 1; i <= n; ++i) d[i] = inf;d[st] = 0;queue<int> q;       //队列存储需要更新的点bitset<N> inq;      //inq[i]表示第i个点在不在队列中q.push(st);vector<int> cnt(n + 1);     //计数while(q.size())     {int x = q.front(); q.pop(); inq[x] = false;for(auto [y, w] : g[x])         //更新所有边{if(d[y] > d[x] + w)         //如果能被更新,更新且入队{if(++ cnt[y] >= n) return true;d[y] = d[x] + w;if(!inq[y]){q.push(y);inq[y] = true;}}}}return false;
}void solve()
{cin >> n >> m;for(int i = 0; i <= n; ++i) g[i].clear();for(int i = 1; i <= m; ++i){int op, x, y; cin >> op >> x >> y;if(op == 1){ll w; cin >> w;g[y].push_back({x, w});}if(op == 2){ll w; cin >> w;g[x].push_back({y, -w});}if(op == 3){g[y].push_back({x, 0});g[x].push_back({y, 0});}}for(int i = 1; i <= n; ++i) g[0].push_back({i, 0});if(spfa(0)) cout << "NO" << '\n';else cout << "YES" << '\n';
}int main()
{ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);int _; cin >> _;while(_--) solve();return 0;
}

最后因为不等式组的解不唯一,输出时挑一个满足题意的解,只需要将距离数组 d d d输出即可。

http://www.yayakq.cn/news/575397/

相关文章:

  • 石家庄高端外贸建站做车展的网站
  • 微信网站建设价格程序员培训机构有哪些
  • 网站优化毕业设计私人做网站要多少钱
  • 泉州网站建设有哪些wordpress的app怎么用
  • 什么网站系统做的最好网站建设技能考试试题三
  • 深圳勘察设计协会网站青岛知名网站建设
  • 湖南网站推广多少钱wordpress-move
  • 餐饮行业网站建设风格seo销售
  • 工作室装修网站源码wordpress内容插件
  • wordpress安装网站吗深圳网络营销技巧
  • 北京朝阳区网站建设公司泉州搜索推广
  • 淘宝客怎么做自己网站推广有了域名和空间怎么做网站内容
  • 要学做游戏上什么网站学好庞各庄网站建设公司
  • 有好看图片的软件网站模板云主机放多个网站
  • 天津智能网站建设哪家好php做的网站代码
  • 台州做网站需要多少钱徐州网站设计网
  • 网站界面设计规划建卖手机网站
  • 网站设计样例佛山多语网站制作
  • 商城系统网站模板评论凡科网站建设怎么样
  • 嘉兴企业网站制作周口网站设计制作
  • 网站建设公司方案百度售后服务电话人工
  • wordpress虚化主题青岛网站排名优化
  • 免费购物网站建设交换链接网站
  • 顺德营销型网站一站式服务哪家好专业电商网站
  • 企业做网站需要注意事项淘宝店铺推广渠道有哪些
  • 做家教什么网站seo优化的主要任务包括
  • 电子商务网站备案好的网页网站设计
  • 人才网网站建设方案用阿里云服务器搭建wordpress
  • 家具网站建设策划书东莞建设一个网站
  • 做音频的网站网站用什么语言做会比较好