NYIST 1006 偷西瓜

偷西瓜

时间限制: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 }

时间: 2024-12-21 13:20:21

NYIST 1006 偷西瓜的相关文章

nyoj 1006(最短路次短路)

偷西瓜 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描述 对于农村的孩子来说最大的乐趣,莫过于和小伙伴们一块下地偷西瓜了,虽然孩子们条件不是很好,但是往往他们很聪明,他们总在计算着到达瓜田的距离,以及逃跑的路线,他们总是以最短的距离冲到瓜田里面,然后以最短的距离回到出发的地方,不过瓜田的大人们已经在他们来的路上等待他们.于是聪明的小伙伴们便不走过的路,即每条路只走一遍,如果小伙伴们回不到出发的地方,他们就说"eating", 我们假设 有 n (n<=

00x00 序

这就开始了吧.猹.西瓜,还有C++!无论是小说还是教材,我都喜欢先读全书最前面的序或背景之类.对于小说,这是为了更好地了解它的背景,而对于教材……则是因为序往往是整本书最好理解的.不过放心吧,我会让后面的内容也好理解的.虽然……序肯定还是略胜一筹-为什么要写这本书?主要是为了应约.当然我早就忘了无数答应的事……吧?不过记起来一个是一个嘛……还有的原因,就是我认为人人都应该有一点编程的知识.可是我也听到很多很多人说,市面上的教材太难太晦涩,翻两页便斗志全无.于是我希望在<猹.西瓜.C++>里,尽

我是超人

如果上帝能听到小乔的祈祷,相信现在坐在自行车上面笑的像个傻逼的男生一定已经被旁边快车道上的卡车撞飞1800次了. 没错,现在以狗吃屎形体趴在地上一脸愤怒的女孩,和那个满脸得意坐在自行车上笑的男孩都是我大学同学. 女孩叫吕乔,我们系出了名的系花.长相确实对的起系花之称.可是这妹子没有人如其名,也没你们想的那么美好,知书达理,温文尔雅.我们这系花同学可是个十足的女汉子.不说话还好,一张嘴就是:你个傻逼,老娘不把你打出屎,算你拉的干净.不得不提,这妹子确实有这实力,她是我们学校的跆拳道协会会长.听说已

JSZX_HC_2016_R5

#1 ccz 200 #2 CTL 130 #3 KPM 130 本来以为准备挺充分的,开始后还是出现一些状况 >_< 好在还算顺利…… A AC人数:4   平均分:70 题目描述 给定一个自然数n,求出所有不大于n的自然数中含有49的数的个数. 对于每个测试数据,输入一个整数n,输出答案. 数据保证输入和答案都在long long范围内. Problem 数位DP,HDU3555 Solution B AC人数:1   平均分:31 在空间中存在两个质点A.B,它们在每个时间点上出现的位置

nyoj1006(最短路次短路spfa)

偷西瓜 时间限制:1000 ms  |  内存限制:65535 KB 难度:4 描述 对于农村的孩子来说最大的乐趣,莫过于和小伙伴们一块下地偷西瓜了,虽然孩子们条件不是很好,但是往往他们很聪明,他们总在计算着到达瓜田的距离,以及逃跑的路线,他们总是以最短的距离冲到瓜田里面,然后以最短的距离回到出发的地方,不过瓜田的大人们已经在他们来的路上等待他们.于是聪明的小伙伴们便不走过的路,即每条路只走一遍,如果小伙伴们回不到出发的地方,他们就说"eating", 我们假设 有 n (n<=

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

1.不快乐的中学时期 我1976年出生于湖南省衡阳市常宁县的农村,没山没水没肉吃,童年时期是很开心的,放牛.捉鱼,偷西瓜,农村小孩子玩过的我都玩过. 初中是乡里的中学,毕业后考入了县的重点高中,高中三年,可能是学习方法和兴趣的原因,成绩一般,1996年参加高考,468分,最低录取线520分,大部分的同学选择了复读,后来基本上考上了大学. 中学期间,我真的不喜欢读书,说是逼着自己学习一点也不过份,特别是写作文,非常痛苦,高考后再也不用考试和写作文,反而解脱了. 2.从五笔打字到Foxpro 我父母

西瓜影视资源逆向+播放器制作(类似天天看)

简介 快播倒下了,西瓜.吉吉等在线播放器又起来,这次它们总结快播的经验设置了底线,从而避免了法律的天网.西瓜.吉吉行为固然可恶,可更可恶的属天天看播放器(申豆),它通过逆向快播.西瓜.优酷.百度获取影视资源,然后盈利上千万.很多同学建议笔者用相同的方法创业,但笔者良心过不去,特此公布天天看等在线播放器制作方法,感兴趣的同学好好研究研究. 本篇讨论开发的方法与技术,不提供代码. 步骤分布如下:1.逆向西瓜影视资源 2.Vlc播放器组件化 3.界面库实现 4.在线播放器实现. 详情 步骤1.逆向西瓜

1006 小明与隔壁老王之间不得不说的故事

1006: 小明与隔壁老王之间不得不说的故事 时间限制: 1 Sec  内存限制: 128 MB提交: 355  解决: 152[提交][状态][讨论版] 题目描述 有一天,小明想偷吃隔壁老王院子里苹果树上的苹果. 但是,老王家有一条哈士奇,每隔一定时间就会吼叫.准确的说,它会在一个时间点吼叫第一次,之后每隔一段时间吼叫两次,比如第一次吼叫是在 t 时刻,间隔为 s,则吼叫时间点为 t, t + s, t + s + 1, t + 2s, t + 2s + 1 等. 小明是个要面子的人,不想被这

[luogu P3786]萃香抱西瓜 [spfa][状态压缩]

题目背景 伊吹萃香(Ibuki Suika)正在魔法之森漫步,突然,许多西瓜(Suika)从四周飞来,划出了绚丽的轨迹.虽然阵势有点恐怖,但她还是决定抱走一些西瓜. 题目描述 萃香所处的环境被简化为一个长为h,宽为w的网格平面.X坐标范围为[1,w],y坐标范围为[1,h]. 她初始(第1个时刻)站在坐标为sx,sy的方格. 西瓜可能在任意一个方格出现,在每个时间单位,它们可能向任何一个方向移动,也可能静止不动.西瓜的位置和移动的轨迹是已知的.西瓜的总数为n个,但只有m个西瓜可以被萃香抱走,因为