分析题意可知:

1、最少须要切断多少边使吴不能找到张(题意吴仅仅能走最短路径上面的边),对从起点到终点的最短路径又一次建图,每条边的权值为1。求最大流就可以

2、在吴能够找到张的前提下,最多能够切断边的数量:仅仅须要在全部最短路径中寻找一条经过边数量最少的最短路径,用边的总数减去它就可以(逆向思维)

代码例如以下:

#include <cstdio>
#include <cstring>
#include <vector>
#include <queue>
#define MAXN 2010
#define INF 1e9+7
using namespace std;
struct Edge
{
int v,cost,cap;///v代表边的还有一个顶点。cost代表边的代价,cap代表反向边的位置
Edge(int _v=0,int _cost=0,int _cap=0):v(_v),cost(_cost),cap(_cap) {}
};
vector<Edge> g[MAXN];///保存地图
vector<int> pre[MAXN];///记录最短路径上每一个节点的父节点,用于构建网络流
int flag[MAXN][MAXN];///解决重边问题
int d[MAXN];///记录到达某一点的最短路径所经过的最短的边,用于求解问题2
int dist[MAXN];
struct qnode
{
int v;
int c;
qnode(int _v=0,int _c=0):v(_v),c(_c) {}
bool operator<(const qnode &r)const
{
return c>r.c;
}
};
int n,m;
int level[MAXN];
void Dijkstra(int s);
void addedge(int u,int v,int w,int cap);
void built(int u);
int DINIC(int s,int t);
int DFS(int now,int maxf,int t);
bool makelevel(int s,int t);
int main()
{
//FILE* fp = fopen("C:\\Users\\Crazy_Bear\\Desktop\\数据\\data1007\\1007.in","rw");
while(scanf("%d%d",&n,&m)==2)
{
memset(g,0,sizeof(g));
memset(flag,0,sizeof(flag));
int x,y,v;
for(int i=1; i<=m; ++i)
{
//fscanf(fp,"%d%d%d",&x,&y,&v);
scanf("%d%d%d",&x,&y,&v);
flag[x][y]++;///记录重边的数量
addedge(x,y,v,0);
flag[y][x]++;
addedge(y,x,v,0);
}
Dijkstra(1);
memset(g,0,sizeof(g));
built(n);///又一次建图
printf("%d %d\n",DINIC(1,n),m-d[n]);
}
// fclose(fp);
return 0;
}
void addedge(int u,int v,int w,int cap)
{
g[u].push_back(Edge(v,w,cap));
}
void Dijkstra(int s)
{
bool vis[MAXN];
for(int i=1; i<=n; ++i)
{
vis[i]=false;
dist[i]=INF;
pre[i].clear();
d[i]=INF;
}
priority_queue<qnode> pq;
while(!pq.empty()) pq.pop();
dist[s]=0;
d[s]=0;
pq.push(qnode(s,0));
qnode tmp;
while(!pq.empty())
{
tmp=pq.top();
pq.pop();
int u=tmp.v;
if(vis[u]) continue;
vis[u]=true;
for(int i=0; i<g[u].size(); ++i)
{
int v=g[u][i].v;
int cost=g[u][i].cost;
if(dist[v]==dist[u]+cost)
{
pre[v].push_back(u);///在求解最短路径的过程中记录父节点
d[v]=min(d[u]+1,d[v]);
}
else if(dist[v]>dist[u]+cost)
{
dist[v]=dist[u]+cost;
pq.push(qnode(v,dist[v]));
d[v]=d[u]+1;
pre[v].clear();
pre[v].push_back(u);
}
}
}
}
void built(int u)
{
if(u==1)
return;
int len=pre[u].size();
for(int i=0; i<len; ++i)
{
if(flag[pre[u][i]][u]>0)
{
addedge(pre[u][i],u,1,g[u].size());
flag[pre[u][i]][u]--;
addedge(u,pre[u][i],1,g[pre[u][i]].size()-1);
flag[u][pre[u][i]]--;
built(pre[u][i]);
}
}
} bool makelevel(int s,int t)
{
memset(level,0,sizeof(level));
level[s]=1;
int que[MAXN];
int iq=0;
que[iq++]=s;
int top;
for(int i=0; i<iq; ++i)
{
top=que[i];
if(top==t) return true;
int len=g[top].size();
for(int i=0; i<len; ++i)
{
if(!level[g[top][i].v]&&g[top][i].cost)
{
que[iq++]=g[top][i].v;
level[g[top][i].v]=level[top]+1;
}
}
}
return false;
}
int DFS(int now,int maxf,int t)
{ if(now==t) return maxf;
int ret=0,f;
int len=g[now].size();
for(int i=0; i<len; ++i)
{
if(g[now][i].cost&&level[g[now][i].v]==level[now]+1)
{
f=DFS(g[now][i].v,min(maxf-ret,g[now][i].cost),t);
g[now][i].cost-=f;
g[g[now][i].v][g[now][i].cap].cost+=f;
ret+=f;
if(ret==maxf) return ret;
}
}
return ret;
}
int DINIC(int s,int t)
{
int ans=0;
while(makelevel(s,t)) ans+=DFS(s,INF,t);
return ans;
}

hdu5249 Tricks Device(网络流最大匹配)的更多相关文章

  1. HDU 5294 Tricks Device 网络流 最短路

    Tricks Device 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5294 Description Innocent Wu follows D ...

  2. Tricks Device (hdu 5294 最短路+最大流)

    Tricks Device Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) To ...

  3. hdu 5294 Tricks Device 最短路建图+最小割

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5294 Tricks Device Time Limit: 2000/1000 MS (Java/Other ...

  4. HDU 5294 Tricks Device (最大流+最短路)

    题目链接:HDU 5294 Tricks Device 题意:n个点,m条边.而且一个人从1走到n仅仅会走1到n的最短路径.问至少破坏几条边使原图的最短路不存在.最多破坏几条边使原图的最短路劲仍存在 ...

  5. HDU5294 Tricks Device(最大流+SPFA) 2015 Multi-University Training Contest 1

    Tricks Device Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) To ...

  6. SPFA+Dinic HDOJ 5294 Tricks Device

    题目传送门 /* 题意:一无向图,问至少要割掉几条边破坏最短路,问最多能割掉几条边还能保持最短路 SPFA+Dinic:SPFA求最短路时,用cnt[i]记录到i最少要几条边,第二个答案是m - cn ...

  7. HDOJ 5294 Tricks Device 最短路(记录路径)+最小割

    最短路记录路径,同一时候求出最短的路径上最少要有多少条边, 然后用在最短路上的边又一次构图后求最小割. Tricks Device Time Limit: 2000/1000 MS (Java/Oth ...

  8. 2015 Multi-University Training Contest 1 Tricks Device

    Tricks Device Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

  9. HDU 5294 Tricks Device(多校2015 最大流+最短路啊)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5294 Problem Description Innocent Wu follows Dumb Zha ...

随机推荐

  1. 利用Python对文件进行批量重命名

    最近几天工作的内容是对40个项目进行考核,每个项目都需要一个考核评分表,已经有了项目的列表. 如果用常规的方法,需要复制40个文件,并逐个修改,不光工作量大,也容易出错,后期修改也不方便. 于是想到了 ...

  2. Jquery学习总结(3)——Jquery获取当前城市的天气信

    Jquery代码: function findWeather() {     var cityUrl = 'http://int.dpool.sina.com.cn/iplookup/iplookup ...

  3. java中的接口中的方法

    题目如下:(多选题)请选择以下接口定义正确的方法() A:public static void main (String[] args); B:private void test(); C:publi ...

  4. Lock-less and zero copy messaging scheme for telecommunication network applications

    A computer-implemented system and method for a lock-less, zero data copy messaging mechanism in a mu ...

  5. COGS——T 438. 烦人的幻灯片

    http://www.cogs.pro/cogs/problem/problem.php?pid=438 ★☆   输入文件:slides.in   输出文件:slides.out   简单对比时间限 ...

  6. 在Html5中与服务器交互

    转自原文 在Html5中与服务器交互 刚刚涉足职场,上头就要我研究HTML5,内嵌到手机上,这对我来说完全是一个陌生的领域,不过也正好给自己一个机会来学习,最近做到要跟服务器交互这部分,这部分可是卡了 ...

  7. 百度分页效果之纯jsp版

    数据库连接工具类 package com.gao.page.utils; import java.sql.Connection; import java.sql.DriverManager; publ ...

  8. POJ 1496 POJ 1850 组合计数

    Code Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 8256 Accepted: 3906 Description Tran ...

  9. m_Orchestrate learning system---十六、如何快速在一堆字符图标中找到所需

    m_Orchestrate learning system---十六.如何快速在一堆字符图标中找到所需 一.总结 一句话总结:find查找字符 比如说找teacher feedback 的图标,可以多 ...

  10. nyoj--747--蚂蚁的难题(三)(dp背包)

    蚂蚁的难题(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:4 描述 蚂蚁终于把尽可能多的食材都搬回家了,现在开始了大厨计划. 已知一共有 n 件食材,每件食材有一个美味度  ...