hunnu--11545--小明的烦恼——找路径
小明的烦恼——找路径 |
Time Limit: 2000ms, Special Time Limit:5000ms, Memory Limit:32768KB |
Total submit users: 45, Accepted users: 36 |
Problem 11545 : No special judgement |
Problem description |
小明真的是个非常厉害的人,每当老师有什么事时。总是会找到小明,二小明也总能解决。所以老师决定给小明一个奖励。给他额外的假期。小明当然非常高兴。由于小明最终能够如愿的出去旅游了。小明旅游的第一站到了漂亮的长沙。到了长沙当然免不了要去參观古色古香的的湖南师范大学了。小明在师大校园里愉快的玩耍,不时瞅一眼从他身边经过的美女。也感叹这个校园古老建筑带给他的震撼。
临近中午了。小明走到了理学院大门前,瞬间就被吸引了,于是就走了进去。在理学院的一个教室外面。小明看到有个带眼睛的男生在皱眉头,好像是被什么难题卡住了。小明的慈悲之心油然而生,于是就走了进去。 于是题目就来了: |
Input |
由多组case: 每组case第一行有4个整数N,M。T,C,N<=200;C<=1000000; 然后有M行。每一行有3个整数,a,b。c,代表从a城市到b城市须要c的油量。 c<=1000000;假设两个城市之间有多条边。则视为不同的边。 |
Output |
对于每一个case: 假设project师可以完毕任务,输出YES,不然输出NO。 |
Sample Input |
|
Sample Output |
|
Problem Source |
HUNNU contest |
题意:问能否找到t条从1到n的路径。每条不能有不论什么重叠,每小段路径能够走的条件是耗油量不大于c
解析:网络流水水就能飘过
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <queue>
- #define MAX(a,b) a>b?a:b
- #define MIN(a,b) a<b?a:b
- #define Max 1000000000
- using namespace std;
- int n,m,t,c,map[222][222];
- int v[222],f[222],dis[222];
- int EK()
- {
- int i,j,k,l,cur,sum,mm,flag,num=0;
- while(true)
- {
- queue<int> q;
- memset(v,0,sizeof(v));//用来记录每次从1找到n的过程中每一个点是否被訪问
- memset(f,0,sizeof(f));//记录1到n的路径
- q.push(1);
- dis[1]=1<<30;
- flag=0;
- while(q.size())//直接广搜找一条从1到n的路径
- {
- cur=q.front();
- q.pop();
- for(i=2;i<=n;i++)
- if(!v[i]&&map[cur][i]<=c)//推断是否已经訪问过,耗油量是否同意通过
- {
- v[i]=1;
- q.push(i);
- f[i]=cur;//记录路径
- if(i==n){flag=1;break;}//假设找到了就标记并退出广搜
- }
- }
- if(!flag||num>=t)break;//假设没有找到从1到n的路径(即增广路)或者找到的路径数已经有了t条了。跳出循环
- num++;//找到路径数加一
- for(i=n;i!=1;i=f[i])//操作找到的这条路径
- {
- map[i][f[i]]=map[f[i]][i];//残余网络,给予网络流回流的机会(这里不能省。不要由于输入是双向就省略。当这段路径是回流路径的时候,它的反方向的值是max)
- map[f[i]][i]=Max;//正向初始化为max,表示已经被走过了,由于c再大也不会大于max
- }
- }
- if(num>=t)puts("YES");
- else puts("NO");
- }
- int main(void)
- {
- int i,j,k,l;
- while(~scanf("%d%d%d%d",&n,&m,&t,&c))
- {
- for(i=1;i<=n;i++)
- for(j=1;j<=n;j++)
- {
- map[i][j]=Max;//各路段初始化为max,这样c再大也过不去
- }
- for(i=0;i<m;i++)
- {
- scanf("%d%d%d",&j,&k,&l);
- map[j][k]=l;//无向图建图
- map[k][j]=l;
- }
- EK();
- }
- return 0;
- }
hunnu--11545--小明的烦恼——找路径的更多相关文章
- hunnu 11545小明的烦恼——找路径 (最大流)
小明的烦恼--找路径 Time Limit: 2000ms, Special Time Limit:5000ms, Memory Limit:32768KB Total submit users: ...
- hunnu - 11545 小明的烦恼——找路径 (最大流)
http://acm.hunnu.edu.cn/online/?action=problem&type=show&id=11545 只是要求不经过相同的边,那么每次找出一条增广路T-- ...
- hunnu 小明的烦恼——找字符串
http://acm.hunnu.edu.cn/online/?action=problem&type=show&id=11544&courseid=0 小明的烦恼——找字符串 ...
- hunnu11544:小明的烦恼——找字符串
Problem description 小明是个非常优秀的同学.他除了特别公正外,他也非常细心,当然老师肯定也知道,这不,老师又有事情找他帮忙了.老师每周都会给他一个字符串A.然后问小明" ...
- hnuun 11544 小明的烦恼——找字符串(求环形字符串的最小最大字典序)
http://acm.hunnu.edu.cn/online/?action=problem&type=show&id=11544&courseid=0 最小最大表示法: 求环 ...
- hunnu11543:小明的烦恼——分糖果
Problem description 小明在班里一直是个非常公正的孩子.这点同学和老师都非常清楚,这不,老师每周都会从家里带来一些糖果.然后叫小明把糖果分给其它小朋友,但这个班里的同学都有一个非 ...
- 擅长排列的小明 II(找规律)
擅长排列的小明 II 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 小明十分聪明,而且十分擅长排列计算. 有一天小明心血来潮想考考你,他给了你一个正整数n,序列1,2, ...
- 【贪心+堆】XMU 1584 小明的烦恼
题目链接: http://acm.xmu.edu.cn/JudgeOnline/problem.php?id=1584 题目大意: 给n(n<=100 000)个任务的耗时和截至时间,问最少不能 ...
- 小明历险记:规则引擎drools教程一
小明是一家互联网公司的软件工程师,他们公司为了吸引新用户经常会搞活动,小明常常为了做活动加班加点很烦躁,这不今天呀又来了一个活动需求,我们大家一起帮他看看. 小明的烦恼 活动规则是根据用户购买订单的金 ...
随机推荐
- Java使用Robot完成QQ轰炸机
效果 网上吵架吵不过别人怎么办?女朋友让你从1数到10000怎么办?想恶搞朋友怎么办?QQ轰炸机你值得拥有!(注:为了更好的学习编程,敲的练手项目,仅作学习使用) 自定义发送内容,自定义发送条数,&q ...
- iptables防火墙简介
原文地址:http://drops.wooyun.org/tips/1424 一.iptables介绍 linux的包过滤功能,即linux防火墙,它由netfilter 和 iptables 两个组 ...
- luogu3231 [HNOI2013]消毒
前置技能:poj3041 如果是二维平面有一些方块,这些方块被染了黑色,你每次可以选择 \((x,y)\) 的区域染成白色,代价是 \(\min(x,y)\),问你付出的最小代价 显然我们不会这么染 ...
- [转]Mac屏幕录像转成gif
http://note.axiaoxin.com/contents/mac-video2gif.html 屏幕录像 打开Quicktime Player -> 文件 -> 新建屏幕录像 - ...
- python3--__repr_和__str__会返回字符串表达形式
__repr_和__str__会返回字符串表达形式 下一个例子是已经见过的init构造方法和add重载方法,本例也会定义返回实例的字符串表达形式的__repr__方法.字符串格式把self.data对 ...
- CSU-1803: 2016 ,同余定理!
int main() { int n,m; while(~scanf("%d%d",&n,&m)) { int r1=n/2 ...
- LINQ学习笔记 Join 与 Group join
LINQ中的Join对应T-SQL中的内连接,并无左连接的方法,当然也没有右连接. 要达成Left join必须依靠GroupJoin来完成. GroupJoin顾名思义就是先集团在做加入,加入的不同 ...
- 2.ruby基本语法,类的定义
1.在ruby中的定义class,ruby中定义类也是以关键字class开头 后面带着类名,类名以大写开头.一个类的结束以关键字end 结束.如: class Customer end 2.ruby类 ...
- bzoj 5055: 膜法师 树状数组+离散
先枚举每一个数,看它前面有几个比它小,算一下和为sum1,后面有几个比它大,算一下和为sum2,对答案的贡献为A[i]*sum1*sum2. 离散化后,树状数组就可以了. 就是倒着一边,顺着一边,统计 ...
- scrapy框架之comand line tool
一 Global Command 1 startproject https://docs.scrapy.org/en/latest/topics/commands.html#startproject ...