分析:设每个人的糖果数量是a[i] 最终就是求a[n]-a[1]的最大值

然后给出m个关系 u,v,c 表示a[u]+c>=a[v] 就是a[v]-a[u]<=c

所以对于这种情况,按照u,v,c建单向边,一条从1到n的路径就是一个关于1和n的推广不等式a[n]-a[1]<=k(k为这条路的权)

所以找到所有不等式中最小k,就是求1到n的最短路,这就是差分约束

然后上代码:

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<queue>
  4. #include<cstdlib>
  5. #include<algorithm>
  6. #include<vector>
  7. #include<cmath>
  8. using namespace std;
  9. typedef long long LL;
  10. const int N=3e4+;
  11. const int INF=0x3f3f3f3f;
  12. struct Edge{
  13. int v,w,next;
  14. bool operator<(const Edge &e)const{
  15. return w>e.w;
  16. }
  17. }edge[N*];
  18. int head[N],tot,n,m,d[N];
  19. void add(int u,int v,int w){
  20. edge[tot].v=v;
  21. edge[tot].w=w;
  22. edge[tot].next=head[u];
  23. head[u]=tot++;
  24. }
  25. priority_queue<Edge>q;
  26. bool vis[N];
  27. int dij(int s,int t){
  28. for(int i=;i<=n;++i)d[i]=INF,vis[i]=;
  29. d[s]=,q.push(Edge{s,,});
  30. while(!q.empty()){
  31. while(!q.empty()&&vis[q.top().v])q.pop();
  32. if(q.empty())break;
  33. int u=q.top().v;
  34. q.pop();
  35. vis[u]=;
  36. for(int i=head[u];~i;i=edge[i].next){
  37. int v=edge[i].v;
  38. if(!vis[v]&&d[v]>d[u]+edge[i].w){
  39. d[v]=d[u]+edge[i].w;
  40. q.push(Edge{v,d[v],});
  41. }
  42. }
  43. }
  44. return d[t];
  45. }
  46. int main(){
  47. scanf("%d%d",&n,&m);
  48. memset(head,-,sizeof(head)),tot=;
  49. for(int i=;i<=m;++i){
  50. int u,v,w;
  51. scanf("%d%d%d",&u,&v,&w);
  52. add(u,v,w);
  53. }
  54. printf("%d\n",dij(,n));
  55. return ;
  56. }

POJ 3159 Candies 差分约束dij的更多相关文章

  1. [poj 3159]Candies[差分约束详解][朴素的考虑法]

    题意 编号为 1..N 的人, 每人有一个数; 需要满足 dj - di <= c 求1号的数与N号的数的最大差值.(略坑: 1 一定要比 N 大的...difference...不是" ...

  2. poj 3159 Candies 差分约束

    Candies Time Limit: 1500MS   Memory Limit: 131072K Total Submissions: 22177   Accepted: 5936 Descrip ...

  3. POJ 3159 Candies (图论,差分约束系统,最短路)

    POJ 3159 Candies (图论,差分约束系统,最短路) Description During the kindergarten days, flymouse was the monitor ...

  4. POJ 3159 Candies(SPFA+栈)差分约束

    题目链接:http://poj.org/problem?id=3159 题意:给出m给 x 与y的关系.当中y的糖数不能比x的多c个.即y-x <= c  最后求fly[n]最多能比so[1] ...

  5. POJ 3159 Candies(差分约束,最短路)

    Candies Time Limit: 1500MS   Memory Limit: 131072K Total Submissions: 20067   Accepted: 5293 Descrip ...

  6. POJ 3159 Candies 解题报告(差分约束 Dijkstra+优先队列 SPFA+栈)

    原题地址:http://poj.org/problem?id=3159 题意大概是班长发糖果,班里面有不良风气,A希望B的糖果不比自己多C个.班长要满足小朋友的需求,而且要让自己的糖果比snoopy的 ...

  7. POJ 3159 Candies(差分约束+spfa+链式前向星)

    题目链接:http://poj.org/problem?id=3159 题目大意:给n个人派糖果,给出m组数据,每组数据包含A,B,C三个数,意思是A的糖果数比B少的个数不多于C,即B的糖果数 - A ...

  8. 图论--差分约束--POJ 3159 Candies

    Language:Default Candies Time Limit: 1500MS   Memory Limit: 131072K Total Submissions: 43021   Accep ...

  9. (简单) POJ 3159 Candies,Dijkstra+差分约束。

    Description During the kindergarten days, flymouse was the monitor of his class. Occasionally the he ...

随机推荐

  1. Linux Vi的使用

    1.vi使用三模式:一般模式,插入模式,命令模式 保存和退出vi: 命令模式下 :w 保存 :w 新文件 保存到新文件 类似另存为,新文件存在,报错 :w! 新文件 保存到新文件,新文件存在,覆盖 : ...

  2. 只允许输入数字的TextBox控件

    [实例说明] 可以在TextBox控件中轻松地输入文本信息,输入的文本信息可以包括字母.数字.汉字等. 如果需要用户在TextBox控件中填写年龄信息,那么年龄信息应当只允许数字,怎么限制用户输入其他 ...

  3. 一个简单的WebService实例

    WebService在.NET平台下的作用是在不同应用程序间共享数据与数据交换. 要达到这样的目标,Web services要使用两种技术: XML(标准通用标记语言下的一个子集):XML是在web上 ...

  4. 使用python抓取有路网图书信息(原创)

    以前挺喜欢去有路网买二手书的,但是有路网有个缺陷,就是放在图书列表中的书很多都没货了,尤其是一些热门的方向,比如android,在列表中的书大多都没有货了,你必须一个一个点进入查看详细信息才能得知图书 ...

  5. PHP中使用cURL

    1.cURL介绍 cURL 是一个利用URL语法规定来传输文件和数据的工具,支持很多协议,如HTTP.FTP.TELNET等.最爽的是,PHP也支持 cURL 库.本文将介绍 cURL 的一些高级特性 ...

  6. SQL技术内幕三

    Select 分析一个查询实例 Select empid,year(orderdate) as orderYear,count(*) as orderCount From dbo.orderInfo ...

  7. 一步步学习ASP.NET MVC3 (3)——Razor(1)

    请注明转载地址:http://www.cnblogs.com/arhat 首先这个<一步步学习ASP.NET MVC3>前段时间有些忙,没有顾得上写文章,昨天呢写了3个和ASP.NET的相 ...

  8. 用JavaScript获取一个超链接的绝对URL地址

    对于Web程序员来说,处理简单的URL格式也许会成为一场噩梦.试想一下,一个网址里有很多组成部分都会影响你对它的解析方法: 是否以/字符开头 是否以//开头 是否以?号开头 是否以#号开头 …等等 当 ...

  9. Mac下无法推出硬盘

    Q:刚刚mac使用移动硬盘,使用后推出时弹出无法推出,提示:Finder正在使用中. 解决:打开#活动监视器#(找不到可以在spotlight中搜索),找到Finder应用,双击,强制退出后再启动Fi ...

  10. hadoop-streaming 配置之---参数分割

    map: -D stream.map.output.field.separator=. 定义mapoutput字段的分隔符为. 用户可以自定义分隔符(除了默认的tab) -D stream.num.m ...