hdu5294||2015多校联合第一场1007 最短路+最大流
http://acm.hdu.edu.cn/showproblem.php?
to catch up Dumb Zhang to find out the answers of some questions, however, it’s Dumb Zhang’s intention to keep Innocent Wu in the dark, to do which he has to stop Innocent Wu from getting him. Only via the original shortest ways from the entrance to the end
of the tomb costs the minimum time, and that’s the only chance Innocent Wu can catch Dumb Zhang.
Unfortunately, Dumb Zhang masters the art of becoming invisible(奇门遁甲) and tricks devices of this tomb, he can cut off the connections between chambers by using them. Dumb Zhang wanders how many channels at least he has to cut to stop Innocent Wu. And Innocent
Wu wants to know after how many channels at most Dumb Zhang cut off Innocent Wu still has the chance to catch Dumb Zhang.
For each case,the first line must includes two integers, N(<=2000), M(<=60000). N is the total number of the chambers, M is the total number of the channels.
In the following M lines, every line must includes three numbers, and use ai、bi、li as channel i connecting chamber ai and bi(1<=ai,bi<=n), it costs li(0<li<=100) minute to pass channel i.
The entrance of the tomb is at the chamber one, the end of tomb is at the chamber N.
8 9 1 2 2 2 3 2 2 4 1 3 5 3 4 5 4 5 8 1 1 6 2 6 7 5 7 8 1
2 6
- /**
- hdu5294 最短路+最大流
- 题目大意:给定一个无向图,从起点到终点,仅仅有走最短路。才干在规定时限内到达,问最少去掉几条边使不能到达。最多去掉几条边仍能到达
- 解题思路:http://blog.sina.com.cn/s/blog_15139f1a10102vnx5.html 和官方题解想的一样
- */
- #include<cstdio>
- #include<iostream>
- #include<queue>
- #include<string.h>
- using namespace std;
- const int oo=1e9;
- const int mm=161111;
- const int mn=2330;
- int node,src,dest,edge;
- int ver[mm],flow[mm],_next[mm];
- int head[mn],work[mn],dis[mn],q[mn];
- void prepare(int _node,int _src,int _dest)
- {
- node=_node,src=_src,dest=_dest;
- for(int i=0; i<=node; ++i)head[i]=-1;
- edge=0;
- }
- void addedge(int u,int v,int c)
- {
- ver[edge]=v,flow[edge]=c,_next[edge]=head[u],head[u]=edge++;
- ver[edge]=u,flow[edge]=0,_next[edge]=head[v],head[v]=edge++;
- }
- bool Dinic_bfs()
- {
- int i,u,v,l,r=0;
- for(i=0; i<node; ++i)dis[i]=-1;
- dis[q[r++]=src]=0;
- for(l=0; l<r; ++l)
- for(i=head[u=q[l]]; i>=0; i=_next[i])
- if(flow[i]&&dis[v=ver[i]]<0)
- {
- dis[q[r++]=v]=dis[u]+1;
- if(v==dest)return 1;
- }
- return 0;
- }
- int Dinic_dfs(int u,int exp)
- {
- if(u==dest)return exp;
- for(int &i=work[u],v,tmp; i>=0; i=_next[i])
- if(flow[i]&&dis[v=ver[i]]==dis[u]+1&&(tmp=Dinic_dfs(v,min(exp,flow[i])))>0)
- {
- flow[i]-=tmp;
- flow[i^1]+=tmp;
- return tmp;
- }
- return 0;
- }
- int Dinic_flow()
- {
- int i,ret=0,delta;
- while(Dinic_bfs())
- {
- for(i=0; i<node; ++i)work[i]=head[i];
- while(delta=Dinic_dfs(src,oo))ret+=delta;
- }
- return ret;
- }
- ///==================================================
- const int INF=0x3f3f3f3f;
- const int maxm=511111;
- const int maxn=2111;
- struct EdgeNode
- {
- int to;
- int w;
- int next;
- };
- EdgeNode edges[maxm];
- int N,M;
- int head1[maxn],edge1;
- bool vis[maxn];
- queue <int> que;
- int dis1[maxn],dis2[maxn];
- void addedge1(int u,int v,int c)
- {
- edges[edge1].w=c,edges[edge1].to=v,edges[edge1].next=head1[u],head1[u]=edge1++;
- }
- void init()
- {
- memset(head1,-1,sizeof(head1));
- edge1=0;
- }
- void spfa(int s,int n)//单源最短路(s为起点,n为节点总数)
- {
- int u;
- for (int i=0; i<=n; i++)
- dis1[i]=INF;
- memset(vis,0,sizeof(vis));
- while (!que.empty()) que.pop();
- que.push(s);
- vis[s]=true;
- dis1[s]=0;
- while (!que.empty())
- {
- u=que.front();
- que.pop();
- vis[u]=false;
- for (int i=head1[u]; i!=-1; i=edges[i].next)
- {
- int v=edges[i].to;
- int w=edges[i].w;
- if (dis1[v]>dis1[u]+w)
- {
- dis1[v]=dis1[u]+w;
- if (!vis[v])
- {
- vis[v]=true;
- que.push(v);
- }
- }
- }
- }
- }
- ////========================================
- int aa[60080][3],bb[60080][3];
- int main()
- {
- int n,m;
- while(~scanf("%d%d",&n,&m))
- {
- init();
- for(int i=0;i<m;i++)
- {
- scanf("%d%d%d",&aa[i][0],&aa[i][1],&aa[i][2]);
- addedge1(aa[i][0],aa[i][1],aa[i][2]);
- addedge1(aa[i][1],aa[i][0],aa[i][2]);
- }
- spfa(1,n);
- memcpy(dis2,dis1,sizeof(dis1));
- //printf("dis2->%d\n",dis2[n]);
- spfa(n,n);
- // printf("dis1->%d\n",dis1[1]);
- int k=0;
- for(int i=0;i<m;i++)
- {
- if(dis2[aa[i][0]]>dis2[aa[i][1]])
- swap(aa[i][0],aa[i][1]);
- // printf("n-%d:%d-1 %d %d %d\n",aa[i][1],aa[i][0],dis1[aa[i][1]],aa[i][2],dis2[aa[i][0]]);
- if(dis1[aa[i][1]]+aa[i][2]+dis2[aa[i][0]]==dis2[n])
- {
- bb[k][0]=aa[i][0];
- bb[k++][1]=aa[i][1];
- // printf("%d %d\n",bb[k-1][0],bb[k-1][1]);
- }
- }
- prepare(n+1,1,n);
- for(int i=0;i<k;i++)
- {
- addedge(bb[i][0],bb[i][1],1);
- }
- int ans1=Dinic_flow();
- init();
- for(int i=0;i<k;i++)
- {
- addedge1(bb[i][0],bb[i][1],1);
- addedge1(bb[i][1],bb[i][0],1);
- }
- spfa(1,n);
- //printf("%d\n",dis2[n]);
- int ans2=m-dis1[n];
- printf("%d %d\n",ans1,ans2);
- }
- return 0;
- }
to catch up Dumb Zhang to find out the answers of some questions, however, it’s Dumb Zhang’s intention to keep Innocent Wu in the dark, to do which he has to stop Innocent Wu from getting him. Only via the original shortest ways from the entrance to the end
of the tomb costs the minimum time, and that’s the only chance Innocent Wu can catch Dumb Zhang.
Unfortunately, Dumb Zhang masters the art of becoming invisible(奇门遁甲) and tricks devices of this tomb, he can cut off the connections between chambers by using them. Dumb Zhang wanders how many channels at least he has to cut to stop Innocent Wu. And Innocent
Wu wants to know after how many channels at most Dumb Zhang cut off Innocent Wu still has the chance to catch Dumb Zhang.
For each case,the first line must includes two integers, N(<=2000), M(<=60000). N is the total number of the chambers, M is the total number of the channels.
In the following M lines, every line must includes three numbers, and use ai、bi、li as channel i connecting chamber ai and bi(1<=ai,bi<=n), it costs li(0<li<=100) minute to pass channel i.
The entrance of the tomb is at the chamber one, the end of tomb is at the chamber N.
8 9 1 2 2 2 3 2 2 4 1 3 5 3 4 5 4 5 8 1 1 6 2 6 7 5 7 8 1
2 6
hdu5294||2015多校联合第一场1007 最短路+最大流的更多相关文章
- hdu 5288||2015多校联合第一场1001题
pid=5288">http://acm.hdu.edu.cn/showproblem.php?pid=5288 Problem Description OO has got a ar ...
- 2015 多校赛 第一场 1007 (hdu 5294)
总算今天静下心来学算法.. Description Innocent Wu follows Dumb Zhang into a ancient tomb. Innocent Wu’s at the e ...
- hdu5289 2015多校联合第一场1002 Assignment
题意:给出一个数列.问当中存在多少连续子区间,当中子区间的(最大值-最小值)<k 思路:设dp[i]为从区间1到i满足题意条件的解.终于解即为dp[n]. 此外 如果对于arr[i] 往左遍历 ...
- HDU 4865 Peter's Hobby(2014 多校联合第一场 E)(概率dp)
题意:已知昨天天气与今天天气状况的概率关系(wePro),和今天天气状态和叶子湿度的概率关系(lePro)第一天为sunny 概率为 0.63,cloudy 概率 0.17,rainny 概率 0.2 ...
- HDU 4868 Information Extraction(2014 多校联合第一场 H)
看到这道题时我的内心是奔溃的,没有了解过HTML,只能靠窝的渣渣英语一点一点翻译啊TT. Information Extraction 题意:(纯手工翻译,有些用词可能在html中不是一样的,还多包涵 ...
- HDU 5289 Assignment(多校联合第一场1002)
Assignment Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total ...
- 2015 多校赛 第一场 1002 (hdu 5289)
Description Tom owns a company and he is the boss. There are n staffs which are numbered from 1 to n ...
- 2015 多校赛 第一场 1001 (hdu 5288)
Description OO has got a array A of size n ,defined a function f(l,r) represent the number of i (l&l ...
- HDU 5724 Chess (状态压缩sg函数博弈) 2016杭电多校联合第一场
题目:传送门. 题意:有n行,每行最多20个棋子,对于一个棋子来说,如果他右面没有棋子,可以移动到他右面:如果有棋子,就跳过这些棋子移动到后面的空格,不能移动的人输. 题解:状态压缩博弈,对于一行2^ ...
随机推荐
- IS---InstallShield第二天
在Setup.rul中,新增OnBegin函数 STRING str1,spath,szApplicationPath,szApplicationCmdLine,szCmdLine;function ...
- 把一个string串的所有小写字母转成大写字母的例子来看看看全局函数的使用
今天写了一个小例子,把字符串里面的所有小写字母全部转换成大写字母http://blog.csdn.net/yasaken/article/details/7303903 1 #include &quo ...
- 《C和指针》章节后编程练习解答参考——第5章
5.1 题目: 略 解答代码: #include <stdio.h> int main(void) { char ch; while (((ch = getchar()) != EOF) ...
- Label设置行间距--b
内容摘要 UILabel显示多行文本 UILabel设置行间距 解决单行文本 & 多行文本显示的问题 场景描述 众所周知,UILabel显示多行的话,默认行间距为0,但实际开发中,如果显示多行 ...
- Java实现Http服务器(四)
(1)HTTPServer的监听启动 sun.net.httpserver.ServerImpl类中启动了Socket监听,ServerImpl的内部类Dispatch类启动了Http服务器的监听 / ...
- iOS:不同属性声明方式的解析
代码: /* 属性声明方式说明: ----------------------- 1 @interface ... { id name } @end 这样声明的属性其实可以认为是private属性,因 ...
- java环境变量设置方法
1.安装JDK,安装过程中可以自定义安装目录等信息,例如我们选择安装目录为D:\java\jdk1.5.0_08: 2.安装完成后,右击“我的电脑”,点击“属性”: 3.选择“高 ...
- JSP中使用的模式——JSP+JavaBean
模式二:JSP+Servlet+JavaBean 链接地址:http://wxmimperio.coding.io/?p=189 JSP中两种模式的总结 链接地址:http://wxmimperio. ...
- jQuery设置按钮被点击状态
js和jquery如何使按钮失效,很简单,只要设置disabled属性为true即为不可用状态即可 1.JS方法一: document.getElementByIdx("btn") ...
- 使用Aspose.Word的基础知识整理
var doc = new Document(path); doc.AcceptAllRevisions();//接受所有修订