题目地址:POJ 2983

题意:有N个车站。给出一些点的精确信息和模糊信息。精确信息给出两点的位置和距离。模糊信息给出两点的位置。但距离大于等于一。试确定是否全部的信息满足条件。

思路:事实上就是让你推断是否存在负环。好久才看明确。对于精确消息。能够得出两个差分公式:dis[v] <= dist[u] - w  &&  dist[u] <= dist[v] + w。对于模糊信息。能够得出dis[v] <= dis[u] -1。

PS:做差分约束感觉还是Bellman_ford好用啊。

#include <stdio.h>
#include <math.h>
#include <string.h>
#include <stdlib.h>
#include <iostream>
#include <sstream>
#include <algorithm>
#include <set>
#include <queue>
#include <stack>
#include <map>
using namespace std;
typedef long long LL;
const int inf=0x3f3f3f3f;
const double pi= acos(-1.0);
const double esp=1e-6;
const int maxn=2010;
int dis[maxn],head[2010];
int cnt;
struct node
{
int u,v,w;
int next;
}edge[1000010];
void add(int u,int v,int w)
{
edge[cnt].u=u;
edge[cnt].v=v;
edge[cnt].w=w;
edge[cnt].next=head[u];
head[u]=cnt++;
}
int Bellman_ford(int n)
{
int i,j;
memset(dis,inf,sizeof(dis));
dis[1]=0;
for(i=1;i<=n;i++){
int flag=0;
for(j=0;j<cnt;j++){
int u=edge[j].u;
int v=edge[j].v;
if(dis[v]>dis[u]+edge[j].w){
dis[v]=dis[u]+edge[j].w;
flag=1;
}
}
if(!flag) break;
}
for(i=0;i<cnt;i++){
if(dis[edge[i].v]>dis[edge[i].u]+edge[i].w)
return 0;
}
return 1;
}
int main()
{
int n,m,i;
int u,v,w;
char str;
while(~scanf("%d %d",&n,&m)){
memset(head,-1,sizeof(head));
cnt=0;
while(m--){
getchar();
scanf("%c",&str);
if(str=='P'){
scanf("%d %d %d",&u,&v,&w);
add(u,v,w);
add(v,u,-w);
}
else{
scanf("%d %d",&u,&v);
add(v,u,-1);
}
}
int ans=Bellman_ford(n);
if(ans)
puts("Reliable");
else
puts("Unreliable");
}
return 0;
}

最新文章

  1. UIViewController生命周期
  2. 计算&amp;IO密集型任务的 优化
  3. 数据可视化(4)--jqplot
  4. java的nio之:java的nio系列教程之Scatter/Gather
  5. hdu 1134 Game of Connections
  6. Css 描点
  7. mac版sublime text2包管理器安装步骤
  8. php中遍历数组的方法
  9. 电脑知识--Windows一片
  10. NodeJS Stream 五:双工流
  11. 作为.net程序员学jsp,伤不起
  12. 接口中定义变量必须为public static final的原因
  13. EntityFramework Core 1.1+ Backing Fields(返回字段)
  14. Windows 版本说明,Enterprise、Ultimate、Home、Professional知多少
  15. 谈谈线上CPU100%排查套路
  16. vscode插件和快捷键
  17. DevExpress GridView删除行
  18. python类型强转&amp;二级容器
  19. 9 云计算系列之Cinder的安装与NFS作为cinder后端存储
  20. Python3基础 set add 向集合中加入新的元素

热门文章

  1. GYM - 101147 A.The game of Osho
  2. vue-cli安装sass
  3. Tomcat学习笔记(十三)
  4. 《c程序设计语言》读书笔记-第二个字符串任意一个在第一个字符串出现的位置,未出先返回-1
  5. mac 安装 navicat premium11.2.1400 破解版
  6. js执行时间(调试)
  7. AtCoder Grand Contest 018 A
  8. datatable to list 方法转换
  9. [ CodeVS冲杯之路 ] P3027
  10. 【Web前端】把图片嵌入到css样式表中(附小工具)