题意

当排队等候喂食时,奶牛喜欢和它们的朋友站得靠近些。FJ有N(2<=N<=1000)头奶牛,编号从1到N,沿一条直线站着等候喂食。奶牛排在队伍中的顺序和它们的编号是相同的。因为奶牛相当苗条,所以可能有两头或者更多奶牛站在同一位置上。即使说,如果我们想象奶牛是站在一条数轴上的话,允许有两头或更多奶牛拥有相同的横坐标。
一些奶牛相互间存有好感,它们希望两者之间的距离不超过一个给定的数L。另一方面,一些奶牛相互间非常反感,它们希望两者间的距离不小于一个给定的数D。给出ML条关于两头奶牛间有好感的描述,再给出MD条关于两头奶牛间存有反感的描述。(1<=ML,MD<=10000,1<=L,D<=1000000)
你的工作是:如果不存在满足要求的方案,输出-1;如果1号奶牛和N号
奶牛间的距离可以任意大,输出-2;否则,计算出在满足所有要求的情况下,1号奶牛和N号奶牛间可能的最大距离。


题解

差分约束,第一种A向B连权值为v的边,第二种B向A连-v的边。
SPFA当有环时,-2;跑不到n, -1 我打的是DFS


常数巨大的丑陋代码

  1. # include <stdio.h>
  2. # include <stdlib.h>
  3. # include <iostream>
  4. # include <string.h>
  5. # include <math.h>
  6. # define RG register
  7. # define IL inline
  8. # define ll long long
  9. # define mem(a, b) memset(a, b, sizeof(a))
  10. # define Min(a, b) (((a) > (b)) ? (b) : (a))
  11. # define Max(a, b) (((a) < (b)) ? (b) : (a))
  12. using namespace std;
  13. IL int Get(){
  14. RG char c = '!'; RG int x = 0, z = 1;
  15. for(; c > '9' || c < '0'; c = getchar()) z = c == '-' ? -1 : 1;
  16. for(; c <= '9' && c >= '0'; c = getchar()) x = x * 10 + c - '0';
  17. return x * z;
  18. }
  19. const int MAXN = 1001, MAXM = 20001, INF = 2147483647;
  20. int n, dis[MAXN], vis[MAXN], ft[MAXN], m1, cnt, m2, flag;
  21. struct Edge{
  22. int to, f, nt;
  23. } edge[MAXM];
  24. IL void Add(RG int u, RG int v, RG int f){
  25. edge[cnt] = (Edge){v, f, ft[u]}; ft[u] = cnt++;
  26. }
  27. IL void Dfs(RG int u){
  28. vis[u] = 1;
  29. if(flag) return;
  30. for(RG int e = ft[u]; e != -1; e = edge[e].nt){
  31. RG int v = edge[e].to, f = edge[e].f + dis[u];
  32. if(dis[v] > f){
  33. dis[v] = f;
  34. if(vis[v]){
  35. flag = 1;
  36. return;
  37. }
  38. Dfs(v);
  39. }
  40. }
  41. vis[u] = 0;
  42. }
  43. int main(){
  44. mem(dis, 63); mem(ft, -1);
  45. n = Get(); m1 = Get(); m2 = Get();
  46. for(RG int i = 1; i <= m1; i++){
  47. RG int u = Get(), v = Get(), f = Get();
  48. Add(u, v, f);
  49. }
  50. for(RG int i = 1; i <= m2; i++){
  51. RG int u = Get(), v = Get(), f = Get();
  52. Add(v, u, -f);
  53. }
  54. dis[1] = 0; Dfs(1);
  55. if(flag) printf("-1\n");
  56. else if(dis[n] == dis[0]) printf("-2\n");
  57. else printf("%d\n", abs(dis[n]));
  58. return 0;
  59. }

poj-3169Layout的更多相关文章

  1. POJ——3169Layout(差分约束)

    POJ——3169Layout Layout Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14702   Accepted ...

  2. POJ 3370. Halloween treats 抽屉原理 / 鸽巢原理

    Halloween treats Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 7644   Accepted: 2798 ...

  3. POJ 2356. Find a multiple 抽屉原理 / 鸽巢原理

    Find a multiple Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 7192   Accepted: 3138   ...

  4. POJ 2965. The Pilots Brothers' refrigerator 枚举or爆搜or分治

    The Pilots Brothers' refrigerator Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 22286 ...

  5. POJ 1753. Flip Game 枚举or爆搜+位压缩,或者高斯消元法

    Flip Game Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 37427   Accepted: 16288 Descr ...

  6. POJ 3254. Corn Fields 状态压缩DP (入门级)

    Corn Fields Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 9806   Accepted: 5185 Descr ...

  7. POJ 2739. Sum of Consecutive Prime Numbers

    Sum of Consecutive Prime Numbers Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 20050 ...

  8. POJ 2255. Tree Recovery

    Tree Recovery Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11939   Accepted: 7493 De ...

  9. POJ 2752 Seek the Name, Seek the Fame [kmp]

    Seek the Name, Seek the Fame Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 17898   Ac ...

  10. poj 2352 Stars 数星星 详解

    题目: poj 2352 Stars 数星星 题意:已知n个星星的坐标.每个星星都有一个等级,数值等于坐标系内纵坐标和横坐标皆不大于它的星星的个数.星星的坐标按照纵坐标从小到大的顺序给出,纵坐标相同时 ...

随机推荐

  1. [Python Study Notes]CS架构远程访问获取信息--Client端v1.0

    更新内容: 1.添加entry栏默认ip和port口 2.修正退出功能 3.添加退出自动关闭窗口功能 4.优化cpu显示为固定保留两位小数 '''''''''''''''''''''''''''''' ...

  2. 购物车【JavaWeb小项目、简单版】

    前言 为了巩固MVC的开发模式,下面就写一个购物车的小案例.. ①构建开发环境 导入需要用到的开发包 建立程序开发包 ②设计实体 书籍实体 public class Book { private St ...

  3. TensorFlow实战之实现自编码器过程

    关于本文说明,已同步本人另外一个博客地址位于http://blog.csdn.net/qq_37608890,详见http://blog.csdn.net/qq_37608890/article/de ...

  4. ios开发常用RGB色值

    iOS中RGB常用的色值,同时可将对颜色的设置定义成宏,方便开发应用,如: // RGB颜色转换(16进制->10进制) #define UIColorFromRGB(rgbValue) [UI ...

  5. virsh 常用操作

    virsh list 显示在运行的 虚拟机    virsh list --all 显示在运行和停止的虚拟机    ssh 192.168.0.115 通过网络连接子机   如果没有网络 可以通过 v ...

  6. memcached 的实践操作

    memcached安装和使用   yum install -y libevent  memcached  libmemcached   启动命令:   /etc/init.d/memcached st ...

  7. .NET平台开源项目速览(19)Power BI神器DAX Studio

    PowerBI更新频繁,已经有点更不上的节奏,一直在关注和学习中,基本的一些操作大概是没问题,更重要的是注重Power Query,M函数,以及DAX的使用,这才是核心.   上个月研究了DAX的一些 ...

  8. Java爬虫----有道翻译初步

    目标:http://fanyi.youdao.com/ 用爬虫实现翻译功能. 利用f12查看网页Network,可以发现 有关翻译的表单请求通过  http://fanyi.youdao.com/tr ...

  9. 1.8 range

    哈哈,前边忘了介绍这个知识点了,老是用人家,不介绍一下都不好意思了. range()函数是一个用来创建数字序列的函数. 问题来了,为什么要写函数? 封装代码啊,让使用者不需要关心具体业务逻辑是如何实现 ...

  10. 关键字final的用法

    final关键字可以用来修饰类.方法和变量. 1.final修饰的类不能被继承. 2.final修饰的方法不能被重写. 3.final修饰的变量是常量,不能修改其值.