题意:有一串数字1~n,按顺序排序,给两种要求,一是给定u,v保证pos[v] - pos[u] <= w;二是给定u,v保证pos[v] - pos[u] >= w。求pos[n] - pos[1]最大,若无解输出-1,无穷多解输出-2。

思路:光看题目好像和最短路无关,其实这里用到了spfa的松弛操作来保证所给出的两种要求。若pos[v] - pos[u] >= w,则pos[v] +(- w) >=  pos[u],也就是pos[v] +(- w) < pos[u]时进行松弛,建一条边v->u,权值-w,这就和spfa中的那一步对应上了,于是转化为了最短路。另一种条件也是如此操作。无解的情况应为出现了负环;无穷多解的情况为1和n没有条件约束,也就是1没有路通向n。

参考:

夜深人静写算法(四) - 差分约束

代码:

#include<cstdio>
#include<set>
#include<cmath>
#include<stack>
#include<vector>
#include<queue>
#include<cstring>
#include<string>
#include<sstream>
#include<iostream>
#include<algorithm>
#define ll long long
using namespace std;
const int maxn = +;
const int INF = 0x3f3f3f3f;
struct Edge{
int v,cost;
Edge(int _v = ,int _cost = ):v(_v),cost(_cost){}
};
vector<Edge> G[maxn];
bool vis[maxn];
int cnt[maxn];
int dist[maxn];
void addEdge(int u,int v,int cost){
G[u].push_back(Edge(v,cost));
}
bool spfa(int st,int n){
memset(vis,false,sizeof(vis));
memset(dist,INF,sizeof(dist));
vis[st] = true;
dist[st] = ;
queue<int> q;
while(!q.empty()) q.pop();
q.push(st);
memset(cnt,,sizeof(cnt));
cnt[st] = ;
while(!q.empty()){
int u = q.front();
q.pop();
vis[u] = false;
for(int i = ;i < G[u].size();i++){
int v = G[u][i].v;
if(dist[v] > dist[u] + G[u][i].cost){
dist[v] = dist[u] + G[u][i].cost;
if(!vis[v]){
vis[v] = true;
q.push(v);
if(++cnt[v] > n) return false;
}
}
}
}
return true;
}
int main(){
int n,ml,md;
scanf("%d%d%d",&n,&ml,&md);
for(int i = ;i <= n;i++) G[i].clear();
for(int i = ;i <= ml;i++){ //at most -> v - u <= w -> v <= w + u
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
addEdge(u,v,w);
}
for(int i = ;i <= md;i++){ //at least -> v - u >= w -> u <= -w + v
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
addEdge(v,u,-w);
}
bool cannot = spfa(,n);
if(!cannot){
printf("-1\n");
}
else{
if(dist[n] == INF){
printf("-2\n");
}
else{
printf("%d\n",dist[n]);
}
}
return ;
}

最新文章

  1. Flex 布局
  2. vmware安装cent os 6.5 + oracle 11g xe + jboss eap 6.2 + weblogic 12c+ webshpere mq 7.5
  3. strcmp函数使用总结
  4. iOS 图片填充 UIImageView
  5. 【转】AngularJS 日期格式化 字典
  6. TinyXml高速入门(一)
  7. HTTP协议4之缓存--转
  8. C#使用LitJson解析JSON(转)
  9. servlet的执行原理与生命周期
  10. C语言描述二叉树的实现及操作(链表实现)
  11. sql server 高可用日志传送
  12. vue2.0 日历日程表 ,可进行二次开发.
  13. Hibernate注意项
  14. LG1912 [NOI2009]诗人小G
  15. python的十进制与任意进制的转换
  16. 【Python编程:从入门到实践】chapter3 列表简介
  17. [T-ARA][지난 달력][旧挂历]
  18. Jmeter----连接mysql数据库及常见问题处理
  19. Leetcode 之Anagrams(35)
  20. MySQL- 常用的MySQL函数,指令等

热门文章

  1. Android Fingerprint系列之google原生界面
  2. 高中生的IT之路-1.2离开校园
  3. python webdriver中对不同下拉框通过文本值的选择
  4. Swift - 获取当前系统时间
  5. 170518、FastDFS_配置文件详解
  6. CH1402 后缀数组【Hash】【字符串】【二分】
  7. 利用Dockerfile构建一个基于CentOS 7镜像
  8. kafka集群与zookeeper集群 配置过程
  9. 洛谷P2325王室联邦 SCOI2005 构造+树上分块
  10. redis知识总汇