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大会上开始自己的 ...
随机推荐
- python-1基础总结
输入 >>> name = input() 1--如果字符串里面有很多字符都需要转义,就需要加很多\,为了简化,Python还允许用r''表示''内部的字符串默认不转义,可以自己试 ...
- 小白日记1:kali环境Wpscan渗透Wordpress
一.什么是Wpscan?什么是Wordpres? 1.Wpscan WPScan是一款针对wordpress的安全扫描软件:可以扫描出wordpress的版本,主题,插件,后台用户以及爆破后台用户密码 ...
- cocos2d-x 3.0的入门程序:helloworld
看过了这么多不同方向的应用,发现很多程序入门都是helloworldhelloworld是所有程序员的绝对初恋 先看一下程序的运行结果吧 然后就是他的工程代码 工程的目录有两个 Classes:程序中 ...
- PowerCmd
今天在手机上看慕课网,看到一个好玩的东西.Powercmd. 一开始的感觉是,妈的,我会cmd命令,为什么要用你的cmd? 后来,用了之后,感觉,嗯,还是Powercmd好用.功能强大. 我们来看看它 ...
- myeclipse中项目名有红叉,但项目中文件没有报错的解决办法
导入了别人的项目,各种jar包都放好后,path也都build好了,项目也能正常启动,但是就是项目名有红叉,这是为什么呢? 网上有人说Java build path中的jar包missing了,这是一 ...
- RedHatEnterpriseLinuxServerRelease7.3上配置vsftpd服务器
0.vsftpd与ftp安装 yum install -y vsftpd ftp 1.vsftpd 服务启停相关命令 systemctl start vsftpd systemctl stop vsf ...
- 剑指Offer - 九度1514 - 数值的整数次方
剑指Offer - 九度1514 - 数值的整数次方2013-11-30 00:49 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponen ...
- 《Cracking the Coding Interview》——第13章:C和C++——题目1
2014-04-25 19:13 题目:用C++写一个读取文件倒数K行的方法. 解法:因为是要取倒数K行,所以我的思路是一行一行地读.过程中需要保存一个长度为K的链表,每次新读到一行都将表头节点移到表 ...
- appium 多个设备同时执行
测试需要同时在多个android设备上运行,就需要启动多个appium 使用adb命令获取udid,命令:adb get-serialno 使用的是testng测试框架,代码使用java编写 第一台, ...
- JMeter学习笔记(四) HTTP Cookies 管理器
有些接口执行时,要求要先登录,此时就需要用到 HTTP Cookies 管理器.不过有些项目是使用的token,即添加HTTP信息头管理器,获取登录后的token,至于token与cookies的区别 ...