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大会上开始自己的 ...
随机推荐
- Android 中的反调试技术
比较简单的有下面这两种 调试端口检测, 23946(0x5D8A) Demo: void CheckPort23946ByTcp() { FILE* pfile=NULL; char buf[0x10 ...
- hdu1251统计难题(trie)
统计难题 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131070/65535 K (Java/Others)Total Submi ...
- 页面引入外部字体ttf,如何提取所需要的ttf字体或者加载过慢的解决方法-1127更新
最近几天编写手机端的页面之后,文中需要华文行楷字体,在网上下载后,引入到了自己的前端页面,以为没有什么事了,继续码代码 @font-face { font-family:huawen; src: ur ...
- Eclipse 创建 Java 接口---Eclipse教程第11课
打开新建 Java 接口向导 新建 Java 接口向导可以创建新的 Java 接口.打开向导的方式有: 点击 File 菜单并选择 New > Interface 在 Package Explo ...
- 通过广播关闭应用程序(每个Activity)和连续点击两次返回键关闭应用程序
对于一个应用程序可能有很多个Activity,可能每个人并不想一个个的去关闭Activity,也有可能忘了,那怎么关闭所有的未关闭的Activity呢,其实有很多方法,但是我最喜欢的一种就是通过广播事 ...
- Xcode坑之一Invalid argument
Xcode坑之一Invalid argument 正在搞代码,运行程序时突然发现程序不能再次运行了,一运行就提示Invalid argument 然后FQ各种查啊,试了好多方法都不行,重启,重置,我用 ...
- Java基础-8构造方法
一).构造方法: 在之前我们提到对象的概念以及对象的实例化等,在这里简单回顾下: Man man = new Man(); 语句创建一个对象,new可以理解成创建一个对象的关键字,通过new关键字为对 ...
- 孤荷凌寒自学python第六十六天学习mongoDB的基本操作并进行简单封装5
孤荷凌寒自学python第六十六天学习mongoDB的基本操作并进行简单封装5并学习权限设置 (完整学习过程屏幕记录视频地址在文末) 今天是学习mongoDB数据库的第十二天. 今天继续学习mongo ...
- 基于TensorFlow的循环神经网络(RNN)
RNN适用场景 循环神经网络(Recurrent Neural Network)适合处理和预测时序数据 RNN的特点 RNN的隐藏层之间的节点是有连接的,他的输入是输入层的输出向量.extend(上一 ...
- Win10 WSL Ubuntu18.04 编译安装MySQL5.7
---恢复内容开始--- 在win10 商店中选择 ubuntu18.04 下载地址 http://dev.mysql.com/downloads/mysql/ wget https://cdn.my ...