偷西瓜

时间限制:1000 ms  |  内存限制:65535 KB
难度:4

描述

对于农村的孩子来说最大的乐趣,莫过于和小伙伴们一块下地偷西瓜了,虽然孩子们条件不是很好,但是往往他们很聪明,他们总在计算着到达瓜田的距离,以及逃跑的路线,他们总是以最短的距离冲到瓜田里面,然后以最短的距离回到出发的地方,不过瓜田的大人们已经在他们来的路上等待他们。于是聪明的小伙伴们便不走过的路,即每条路只走一遍,如果小伙伴们回不到出发的地方,他们就说“eating”,

我们假设 有 n (n<=100)个 村庄 m条路(m<=1000)小伙伴们总是从1号村庄出发,而瓜田总是在n号村庄.如果小伙伴们到达不了n号村庄,或者回不到1号村庄请输出"eating";

输入
多组数据
第一行一个整数 n 
第二行 一个整数 m
随后的m行 有 三个数u,v,w 表示u 到 v村庄的距离为w(w<=1000);
输出
求小伙伴们从1号村庄出发,到 n号村庄,再回到1号村庄所用的最短距离,如果不能回到1号村庄请输出“eating”.
样例输入
2
1
1 2 999
3
3
1 3 10
2 1 20
3 2 50
样例输出
eating
80
上传者
ACM_王亚龙

解题:费用流。。。

 1 #include <iostream>
 2 #include <cstdio>
 3 #include <cstring>
 4 #include <cmath>
 5 #include <algorithm>
 6 #include <climits>
 7 #include <vector>
 8 #include <queue>
 9 #include <cstdlib>
10 #include <string>
11 #include <set>
12 #include <stack>
13 #define LL long long
14 #define pii pair<int,int>
15 #define INF 0x3f3f3f3f
16 using namespace std;
17 const int maxn = 110;
18 struct arc{
19     int to,flow,cost,next;
20     arc(int x = 0,int y = 0,int z = 0,int nxt = -1){
21         to = x;
22         flow = y;
23         cost = z;
24         next = nxt;
25     }
26 };
27 arc e[maxn*maxn];
28 int head[maxn],d[maxn],p[maxn],tot,n,m,S,T;
29 void add(int u,int v,int flow,int cost){
30     e[tot] = arc(v,flow,cost,head[u]);
31     head[u] = tot++;
32     e[tot] = arc(u,0,-cost,head[v]);
33     head[v] = tot++;
34 }
35 bool spfa(){
36     queue<int>q;
37     bool in[maxn] = {false};
38     for(int i = S; i <= T; ++i) p[i] = -1,d[i] = INF;
39     d[S] = 0;
40     q.push(S);
41     while(!q.empty()){
42         int u = q.front();
43         q.pop();
44         in[u] = false;
45         for(int i = head[u]; ~i; i = e[i].next){
46             if(e[i].flow && d[e[i].to] > d[u] + e[i].cost){
47                 d[e[i].to] = d[u] + e[i].cost;
48                 p[e[i].to] = i;
49                 if(!in[e[i].to]) {
50                     in[e[i].to] = true;
51                     q.push(e[i].to);
52                 }
53             }
54         }
55     }
56     return p[T] > -1;
57 }
58 bool solve(int &ans){
59     int flow = ans = 0;
60     while(spfa()){
61         int minFlow = INF;
62         for(int i = p[T]; ~i; i = p[e[i^1].to])
63             minFlow = min(e[i].flow,minFlow);
64         for(int i = p[T]; ~i; i = p[e[i^1].to]){
65             e[i].flow -= minFlow;
66             e[i^1].flow += minFlow;
67         }
68         flow += minFlow;
69         ans += d[T]*minFlow;
70     }
71     return flow == 2;
72 }
73 int main() {
74     while(~scanf("%d %d",&n,&m)){
75         tot = S = 0;
76         T = n + 1;
77         int u,v,w;
78         memset(head,-1,sizeof(head));
79         for(int i = 0; i < m; ++i){
80             scanf("%d %d %d",&u,&v,&w);
81             add(u,v,1,w);
82             add(v,u,1,w);
83         }
84         add(S,1,2,0);
85         add(n,T,2,0);
86         int ans;
87         if(solve(ans)) printf("%d\n",ans);
88         else puts("eating");
89     }
90     return 0;
91 }

View Code

转载于:https://www.cnblogs.com/crackpotisback/p/4052082.html

NYIST 1006 偷西瓜相关推荐

  1. 直指Adobe的龌龊行径

    我一直想一吐而快的事,就是TM这个操蛋的Adobe自动更新程序的破事. 这玩意真是全自动.高智能啊,只要你打开任意Adobe软件,它就悄悄的跑到系统托盘里开始下载,这就是嫌它Adobe的程序执行效率还 ...

  2. uniapp 仿网易云音乐播放器 微信小程序

    效果视频: uniapp 仿照网易云播放器功能 效果截图: 上代码: <template><view class=""><scroll-view :s ...

  3. 童年那些牛B的顺口溜 【转】

    1.太阳当空照,花儿对我笑,小鸟说早早早,你为什么背上炸药包?我去炸学校,老师不知道,一拉线我就跑,轰的一声,学校炸飞了!2.星期天的早上大雪茫茫,捡破烂的老头排成一行行,警察一指挥,冲向垃圾堆,破鞋 ...

  4. 小时候短暂的武校经历!

    学武术找韩鹏,这是当时我们那边电视的一个广告语.而我也有幸随着这个潮流,在小学六年级暑假,去了武校学武,当然没有去韩鹏武校,因为贵,所以来到了与它相距100米的一家武校,现在都拆了. 那时候学武的原因 ...

  5. 【转载】从草根到百万年薪程序员的二十年风雨之路

    在写这篇文章之前,该用什么样的标题,我犹豫不定,草根?百万年薪程序员?会不会被人当成标题党.二十年来,我所见过的草根程序员很多,优秀的草根程序员也不少.人与人之间的差别其实很小,很多人因为年少不懂事或 ...

  6. 从草根到百万年薪程序员的二十年风雨之路

    在写这篇文章之前,该用什么样的标题,我犹豫不定,草根?百万年薪程序员?会不会被人当成标题党.二十年来,我所见过的草根程序员很多,优秀的草根程序员也不少.人与人之间的差别其实很小,很多人因为年少不懂事或 ...

  7. 大学计算机word作业我的家乡河南,说说我的家乡河南作文

    我是*家豪,一个土生土长的农村娃. 二岁时,我因对某些东西过敏,从脸到脚,全身长满了痘痘,奶奶依依不舍地说:"秋霞,你把娃带到南京去住吧.别因为过敏,而让脸破相了."说完,就哭了. ...

  8. 离职后竟半夜偷溜回办公室写代码?一个为自由软件而战斗的程序员

    作者 | 年素清 责编 | 王晓曼 出品 | 程序人生 (ID:coder _life) 理查德•马修•斯托曼(Richard MatthewStallman)是个非常厉害的程序员,他开发出了Emac ...

  9. 断点调试 debug模式 1006

    断点调试 debug模式 1006 打断点 在需要监视的位置打断点 调试 F5可以开启调试 或者 调试>启动调试 视频 演练调试模式 c sharp 1006 - 西瓜视频 https://ww ...

最新文章

  1. Python 字典创建、更新、按键值排序、取最大键值对等操作
  2. 监控视频长度压缩算法
  3. Java 数据类型:对人的描述
  4. php 实体转html,PHP 转HTML标签为实体, 把实体html标签转为,过滤html标签 | 学步园...
  5. stm32 usb 虚拟串口 相同_为什么说你要学习USB?(一)
  6. CSS3--5.颜色属性
  7. 畅销书主编推出 MATLAB 春季班,限量优惠+送百G资料!
  8. 黑白棋游戏水平(2)--pytorch剪裁
  9. [转]35个高级Python知识点总结
  10. VC++实现全局钩子勾住消息对话框
  11. python3.6 编程技巧总结
  12. CSS固定定位 将模块固定到版心右边
  13. LiveZilla-最好的免费在线客服
  14. android实现wifi与移动数据的切换
  15. Angular学习笔记——自定义指令directive参数详解
  16. unreal编译源码搭建dedicated server的流水账——但是细
  17. Python模拟锟斤拷等各类乱码
  18. JS文件应该放在什么位置
  19. 联旌智能加入昇腾万里伙伴计划,携手华为共创行业新价值
  20. 领英辅助工具领英精灵分组功能解析

热门文章

  1. Spring+SpringMvc+Mybatis框架集成搭建教程二(依赖配置及框架整合)
  2. Android Studio 如何打JAR包
  3. Oracle安装——虚拟机搭建图解
  4. 24款非常实用的CSS3工具终极收藏
  5. ajaxfileupload带参数上传文件
  6. 北大百年讲堂创新大会小游记
  7. Android Studio 设置编辑器背景颜色
  8. Could not create JarEntryRevision
  9. Tomact和MySql搭建android简单服务器
  10. 分布式离线计算—HiveSQL