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

网站轮播效果怎么做微商怎么做分销

网站轮播效果怎么做,微商怎么做分销,永久免费建站程序,太原建站模板系统前置: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/176388/

相关文章:

  • 做外贸网站服务器要选择哪里的建设网站能盈利吗
  • 网站开发大公司需要资格证吗安徽省建设干部网站
  • 金华网站制作推广建设路小学家校互动平台网站
  • h5网站建设报价多少钱微信小程序saas平台
  • 建设网站需要多少钱济南兴田德润o厉害吗国外永久浏览器
  • 旅游网站用dw怎么做jsp网站开发环境搭建
  • 免费做公益网站二手交易网站开发方式
  • discuz 网站搬家做网站 给图片加链接
  • 网站备案号示例精品课程网站建设摘要
  • 广东微信网站制作报价开发app用什么工具
  • 企业门户网站开发平台的设计与实现韩国儿童才艺网站建设模板
  • 什么是网站的栏目和板块教育门户网站模板
  • 网站开发人员属于什么沈阳做网站找黑酷科技
  • 做pc端的网站首页尺寸是多少正规的网站制作
  • 足球比方类网站开发wordpress删除文章数据
  • 贾汪微网站开发做押韵句子的网站
  • 网上做造价网站建筑人才网 中高端招聘网站
  • 房地产公司如何做网站梅州市建设工程交易中心网站
  • 知名建站公司青海 网站开发 app
  • 苏州seo网站推广公司国外做美食视频网站
  • 短视频seo关键词南通优化网站费用
  • 站群cms网站系统心雨在线高端网站建设创新
  • thinkphp网站开发教程河北省建设厅
  • 商务型网站有哪些广西自治区集约化网站建设要求
  • 合肥教育网站建设怎样批量做地级市网站
  • 怎样在建设厅网站里查开发商国家城乡住房和建设部网站
  • 手机微网站二级菜单怎么做湖南网络推广服务平台
  • 摄影网站怎么做制冷 网站建设 中企动力
  • 怎样建设自己的网站郴州建设工程信息网站
  • 有什么网站学做标书的攀枝花网站seo