UVALIVE 3645 Objective: Berlin
最大流 。以航班为节点进行最大流。 容量限制进行拆点。 如果时间地点满足可以建一条边。 具体看代码。变量名被修改过了。一开始的变量名可能比较容易看懂
但CE了。可能与库里的变量重复了。
AC代码
#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
#define MAXN 15050
const int INF = 0x3f3f3f3f ;
struct node
{
int u,v,next;
int cap,flow;
}edge[];
int cnt,N,M;
int head[MAXN];
int ans;
string stpos,edpos,sti,eti;
map<string,int>place;
struct flight
{
int s,t;
int statime,ndtime;
int num;
}src[MAXN];
int cas,lasttime,a[MAXN];
queue<int>q;
void addedge(int u, int v, int cap)
{
edge[cnt].u = u;
edge[cnt].v = v;
edge[cnt].cap = cap;
edge[cnt].flow = ;
edge[cnt].next = head[u];
head[u] = cnt++; edge[cnt].u = v;
edge[cnt].v = u;
edge[cnt].cap = ;
edge[cnt].flow = ;
edge[cnt].next = head[v];
head[v] = cnt++;
}
void read()
{
place.clear();
cas = ;
cin >> stpos >> edpos;
place[stpos] = cas++; place[edpos] = cas++;
cin >> eti;
lasttime = ((eti[] - '') * + eti[] - '') * + (eti[] - '') * + eti[] - '';
cin >> M;
for (int i = ; i <= M; i++)
{
cin >> stpos >> edpos;
if (!place[stpos]) place[stpos] = cas++;
if (!place[edpos]) place[edpos] = cas++;
cin >> src[i].num;
cin >> sti >> eti;
src[i].statime = ((sti[] - '') * + sti[] - '') * + (sti[] - '') * + sti[] - '';
src[i].ndtime = ((eti[] - '') * + eti[] - '') * + (eti[] -'') * + eti[] - '';
src[i].s = place[stpos];
src[i].t = place[edpos];
}
}
void build()
{
memset(head,-,sizeof(head));
cnt = ;
for (int i = ; i <= M; i++)
{
if (src[i].s == ) addedge(,i,INF);
if (src[i].t == && src[i].ndtime <= lasttime) addedge(i + M,M * + ,INF);
addedge(i, i + M, src[i].num);
for (int j = ; j <= M; j++)
{
if (i == j)continue;
if (src[i].t == src[j].s && src[i].ndtime + <= src[j].statime) addedge(i + M, j,INF);
}
}
}
int Edmonds_karp(int source,int target)
{
while (!q.empty()) q.pop();
int p[MAXN];
int F = ;
while (true)
{
memset(p,-,sizeof(p));
q.push(source);
memset(a,,sizeof(a));
a[source] = INF;
while (!q.empty())
{
int u = q.front(); q.pop();
for (int i = head[u]; i != -; i = edge[i].next)
{
int v = edge[i].v;
if (!a[v] && edge[i].cap > edge[i].flow)
{
a[v] = min(a[u],edge[i].cap - edge[i].flow);
p[v] = i;
q.push(v);
}
}
}
if (a[target] == ) break;
for (int i = p[target]; i != -; i = p[edge[i].u])
{
edge[i].flow += a[target];
edge[i ^ ].flow -= a[target];
}
F += a[target];
}
return F;
}
int main()
{
//freopen("sample.txt","r",stdin);
while (scanf("%d",&N) != EOF)
{
read();
build();
printf("%d\n",Edmonds_karp(, * M + ));
}
return ;
}
CE代码也放在这里容易看懂一些
#include <map>
#include <set>
#include <list>
#include <cmath>
#include <ctime>
#include <deque>
#include <stack>
#include <queue>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <climits>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
#define LL long long
#define PI 3.1415926535897932626
using namespace std;
int gcd(int a, int b) {return a % b == ? b : gcd(b, a % b);}
#define MAXN 15050
const int INF = 0x3f3f3f3f ;
struct node
{
int u,v,next;
int cap,flow;
}edge[];
int cnt,N,M;
int head[MAXN];
int ans;
string stpos,edpos,stime,etime;
map<string,int>place;
struct flight
{
int s,t;
int sttime,edtime;
int num;
}src[MAXN];
int cas,lasttime,a[MAXN];
queue<int>q;
void addedge(int u, int v, int cap)
{
edge[cnt].u = u;
edge[cnt].v = v;
edge[cnt].cap = cap;
edge[cnt].flow = ;
edge[cnt].next = head[u];
head[u] = cnt++; edge[cnt].u = v;
edge[cnt].v = u;
edge[cnt].cap = ;
edge[cnt].flow = ;
edge[cnt].next = head[v];
head[v] = cnt++;
}
void read()
{
place.clear();
cas = ;
cin >> stpos >> edpos;
place[stpos] = cas++; place[edpos] = cas++;
cin >> etime;
lasttime = ((etime[] - '') * + etime[] - '') * + (etime[] - '') * + etime[] - '';
cin >> M;
for (int i = ; i <= M; i++)
{
cin >> stpos >> edpos;
if (!place[stpos]) place[stpos] = cas++;
if (!place[edpos]) place[edpos] = cas++;
cin >> src[i].num;
cin >> stime >> etime;
src[i].sttime = ((stime[] - '') * + stime[] - '') * + (stime[] - '') * + stime[] - '';
src[i].edtime = ((etime[] - '') * + etime[] - '') * + (etime[] - '') * + etime[] - '';
src[i].s = place[stpos];
src[i].t = place[edpos];
}
}
void build()
{
memset(head,-,sizeof(head));
cnt = ;
for (int i = ; i <= M; i++)
{
if (src[i].s == ) addedge(,i,INF);
if (src[i].t == && src[i].edtime <= lasttime) addedge(i + M,M * + ,INF);
addedge(i, i + M, src[i].num);
for (int j = ; j <= M; j++)
{
if (i == j)continue;
if (src[i].t == src[j].s && src[i].edtime + <= src[j].edtime) addedge(i + M, j,INF);
}
}
}
int Edmonds_karp(int source,int target)
{
while (!q.empty()) q.pop();
int p[MAXN];
int F = ;
while (true)
{
memset(p,-,sizeof(p));
q.push(source);
memset(a,,sizeof(a));
a[source] = INF;
while (!q.empty())
{
int u = q.front(); q.pop();
for (int i = head[u]; i != -; i = edge[i].next)
{
int v = edge[i].v;
if (!a[v] && edge[i].cap > edge[i].flow)
{
a[v] = min(a[u],edge[i].cap - edge[i].flow);
p[v] = i;
q.push(v);
}
}
}
if (a[target] == ) break;
for (int i = p[target]; i != -; i = p[edge[i].u])
{
edge[i].flow += a[target];
edge[i ^ ].flow -= a[target];
}
F += a[target];
}
return F;
}
int main()
{
//freopen("sample.txt","r",stdin);
while (scanf("%d",&N) != EOF)
{
read();
build();
printf("%d\n",Edmonds_karp(, * M + ));
}
return ;
}
UVALIVE 3645 Objective: Berlin的更多相关文章
- UVALive 3645 Objective: Berlin(最大流 :时序模型)
题意:已知n(n <= 150)个城市和m(m <= 5000)个航班,每个航班有出发地.到达地.乘坐人数.起飞时间和降落时间(时间用时和分表示),求从一个指定城市出发,去往另一个指定城市 ...
- UVaLive 3645 Objective: Berlin (最大流)
题意:有n个城市,m条航班.已知每条航班的起点和终点,还有每条航班的载客量.出发时间.到达时间.并且要求在任何一个城市(起点.终点除外)都至少要有30分钟的中转时间,求起点到终点的最大客流量. 析:把 ...
- UVa1161 Objective: Berlin(最大流)
题目 Source https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_pr ...
- UVALive-3645 Objective: Berlin (最大流:时序模型)
题目大意:有n个城市,m条航班.已知每条航班的起点和终点,还有每条航班的载客量.出发时间.到达时间.并且要求在任何一个城市(起点.终点除外)都至少要有30分钟的中转时间,求起点到终点的最大客流量. 题 ...
- UVALive 3645 时序模型
按航班拆点 注意返边的条件 #include<bits/stdc++.h> using namespace std; const int maxn = 1e6+11; const int ...
- UVa 1161 Objective: Berlin (最大流)
题意:给定一些航班,每个航班有人数,和起始终止时间,每次转机要花半小时,问限制时间内最多能有多少人从起始城市到终点城市. 析:差不多是裸板网络流的最大流问题,把每个航班都拆成两个点,这两个点之间连接一 ...
- UVA - 1161 Objective: Berlin(最大流+时序模型)
题目大意:有n个城市m条航线.给出每条航线的出发地,目的地,座位数,起飞时间和到达时间(所给形式为HHMM.记得转化),再给出城市A和B.和到达城市B的最晚时间.如今问一天内最多有多少人能从A飞到B, ...
- Automake
Automake是用来根据Makefile.am生成Makefile.in的工具 标准Makefile目标 'make all' Build programs, libraries, document ...
- GOTO Berlin: Web API设计原则
在邮件列表和讨论区中有很多与REST和Web API相关的讨论,下面仅是我个人对这些问题的一些见解,并没有绝对的真理,InnoQ的首席顾问Oliver Wolf在GOTO Berlin大会上开始自己的 ...
随机推荐
- easyPOI导出excel报错
http-nio--exec- at :: - excel cell export error ,data is :com.jn.ssr.superrescue.web.qc.dto.Automati ...
- @ApiModelProperty用法
@ApiModelProperty()用于方法,字段: 表示对model属性的说明或者数据操作更改 value–字段说明 name–重写属性名字 dataType–重写属性类型 required–是否 ...
- [WorldFinal 2012E]Infiltration(dfs+图论)
Description 题意:给定一个点数为n的竞赛图,求图的最小支配集 n<=75 Solution 如果将竞赛图的一个点删去,这个图还是竞赛图 而竞赛图每个点相连的边数为(n-1),那么删去 ...
- talent-aio源码阅读小记(二)
我们上一篇提到了talent-aio的四类Task:DecodeRunnable.HandlerRunnable.SendRunnable.CloseRunnable,并且分析了这些task的基类Ab ...
- 8,Linux系统基础优化及常用命令
Linux基础系统优化 引言没有,只有一张图. Linux的网络功能相当强悍,一时之间我们无法了解所有的网络命令,在配置服务器基础环境时,先了解下网络参数设定命令. ifconfig 查询.设置网卡和 ...
- 网络编程介绍(uninx/windows)
1.网络中进程之间如何通信? 2.Socket是什么? 3.socket的基本操作 3.1.socket()函数 3.2.bind()函数 3.3.listen().connect()函数 3.4.a ...
- async/await 实现协程
2. 基本了解 在了解异步协程之前,我们首先得了解一些基础概念,如阻塞和非阻塞.同步和异步.多进程和协程. 2.1 阻塞 阻塞状态指程序未得到所需计算资源时被挂起的状态.程序在等待某个操作完成期间,自 ...
- 使用Html5shiv.js让ie支持html5
ie低版本不支持html5标签,可以引入一段脚本,在ie浏览器中创建html5的标签. 1,可以在网上下载html5shiv的压缩包,引入压缩版的html5shiv.min.js即可. 脚本引用要在h ...
- css 之 border-radius属性
css中给盒子设置圆角可以通过 border-radius 属性来实现(具体原理就不深入探讨了); 在开发过程中都会遇到浏览器兼容问题,这问题其实也不难解决,无非就是加上私有前缀,在这里先忽略掉. ...
- uiautomator+cucumber实现移动app自动化测试
前提 由于公司业务要求,所以自动化测试要达到以下几点: 跨应用的测试 测试用例可读性强 测试报告可读性强 对失败的用例有截图保存并在报告中体现 基于以上几点,在对自动化测试框架选型的时候就选择了uia ...