hdu5249 Tricks Device(网络流最大匹配)
分析题意可知:
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(网络流最大匹配)的更多相关文章
- HDU 5294 Tricks Device 网络流 最短路
Tricks Device 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5294 Description Innocent Wu follows D ...
- Tricks Device (hdu 5294 最短路+最大流)
Tricks Device Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) To ...
- hdu 5294 Tricks Device 最短路建图+最小割
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5294 Tricks Device Time Limit: 2000/1000 MS (Java/Other ...
- HDU 5294 Tricks Device (最大流+最短路)
题目链接:HDU 5294 Tricks Device 题意:n个点,m条边.而且一个人从1走到n仅仅会走1到n的最短路径.问至少破坏几条边使原图的最短路不存在.最多破坏几条边使原图的最短路劲仍存在 ...
- 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 ...
- SPFA+Dinic HDOJ 5294 Tricks Device
题目传送门 /* 题意:一无向图,问至少要割掉几条边破坏最短路,问最多能割掉几条边还能保持最短路 SPFA+Dinic:SPFA求最短路时,用cnt[i]记录到i最少要几条边,第二个答案是m - cn ...
- HDOJ 5294 Tricks Device 最短路(记录路径)+最小割
最短路记录路径,同一时候求出最短的路径上最少要有多少条边, 然后用在最短路上的边又一次构图后求最小割. Tricks Device Time Limit: 2000/1000 MS (Java/Oth ...
- 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 ...
- HDU 5294 Tricks Device(多校2015 最大流+最短路啊)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5294 Problem Description Innocent Wu follows Dumb Zha ...
随机推荐
- 2、Koa2 路由+cookie
一.koa2 原生路由的实现 const Koa = require('koa'); const app = new Koa(); const fs = require('fs'); function ...
- 利用新版本自带的Zookeeper搭建kafka集群
安装简要说明新版本的kafka自带有zookeeper,其实自带的zookeeper完全够用,本篇文章以记录使用自带zookeeper搭建kafka集群.1.关于kafka下载kafka下载页面:ht ...
- 【POJ 1850】 Code
[POJ 1850] Code 还是非常想说 数位dp真的非常方便! !. 数位dp真的非常方便!.! 数位dp真的非常方便! !! 重要的事说三遍 该题转换规则跟进制差点儿相同 到z时进一位 如az ...
- Solaris 10 改ip參考文档之二
參考自:Cannot change IP address of Solaris[TM] 10 host (Doc ID 1007942.1) 本文不做翻译.全文转载. Symptoms Changin ...
- cocos2dx-3.0创建Android项目时遇到的错误。
cocos run -p android出现 文件名称.文件夹名或卷标语法不对 Updated project.properties Updated local.properties Updated ...
- swift -函数、函数指针
// // main.swift // FunctionTest-04 // import Foundation println("函数測试!") testFunction() / ...
- 基于FPGA的跨时钟域信号处理——专用握手信号
在逻辑设计领域,只涉及单个时钟域的设计并不多.尤其对于一些复杂的应用,FPGA往往需要和多个时钟域的信号进行通信.异步时钟域所涉及的两个时钟之间可能存在相位差,也可能没有任何频率关系,即通常所说的不同 ...
- MongoDB基本概念和安装配置
基本概念 MongoDB直接存储JSON. 有了NoSQL数据库之后,可以直接在业务层将数据按照指定的结构进行存储. NO SQL NoSQL 1 数据库 数据库 2 表 集合 3 行 文档 4 列 ...
- nyoj--914--Yougth的最大化(二分查找)
Yougth的最大化 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 Yougth现在有n个物品的重量和价值分别是Wi和Vi,你能帮他从中选出k个物品使得单位重量的价值最 ...
- crontab任务调度
基本语法 crontab [选项] 选项: -e: 编辑crontab定时任务 -l: 查询crontab任务 -r: 删除当前用户所有的crontab任务 2)参数说明 [root ...