习题:codevs 1035 火车停留解题报告
本蒟蒻又来写解题报告了。这次的题目是codevs 1035 火车停留。
题目大意就是给m个火车的到达时间、停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润,让你来求一种安排方法,使得车站收益最大,并输出收益值。
蒟蒻的思路是这样的:
一眼看出:最大费用最大流(MCMF)
显然cost:表示车站收益
然后……
以车站为点建立图求流?同一个车站可能经过好几辆火车……,貌似很麻烦……;
那么以什么建图、连边,还有怎么连?
貌似有点类似于方格取数2之中的拆点……;
那么这个就可以……以火车为点,把一个点拆成两个,然后建立流的关系。
Reach[i]和stay[i]作为建立不同火车是否可以建边的判断条件
假设火车i,将其分为点2*i-1和2*i,连一条流量为1,费用为-cost[i]的边
如果reach[i] + stay[i] < reach[j],在2*i和2*j-1之间连一条流量为1,费用为0的边。
建立汇点和起点S,T,从S向每个2*i-1连一条流量为1,费用为0的边。从每个2*i向T连一条流量为1,费用为0的边。
那么怎么限制n个车道呢?其实很简单,只需要建立超级汇点ST,然后从T向ST连一条流量为n,费用为0的边。
这样这个题目就大功告成了,代码不长,刚98行。建议大家还是去刷一下代码能力题,因为NOIP2015蒟蒻就被代码能力题给坑惨了。
废话不多说,上代码
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
using namespace std;
const int INF = ;
const int maxe = ;
const int maxn = ;
int n,m,reach[maxn],stay[maxn],cost[maxn],vis[maxn<<],d[maxn<<],h[maxn<<],pre[maxn<<],rid[maxn],cid[maxn],now;
double ans;
struct edge{
int to,cost,cap,next;
}tr[maxe];
inline void init(){
now = ;
memset(h,-,sizeof(h));
memset(tr,,sizeof(tr));
memset(reach,,sizeof(reach));
memset(stay,,sizeof(stay));
memset(cost,,sizeof(cost));
}
inline void add(int u,int v,int cap,int cost){
tr[now].to = v;tr[now].cap = cap;tr[now].cost = cost;tr[now].next = h[u];
h[u] = now++;
tr[now].to = u;tr[now].cap = ;tr[now].cost = -cost;tr[now].next = h[v];
h[v] = now++;
}
bool SPFA(int s,int t,int &flow,int &cost){
for(int i = s;i <= t;++i){
d[i] = INF;
}
int minflow = INF;
memset(vis,,sizeof(vis));
memset(pre,-,sizeof(pre));
deque<int>q;
d[s] = ;
vis[s] = ;
q.push_back(s);
while(!q.empty()){
int x = q.front();q.pop_front();
vis[x] = ;
for(int i = h[x];i != -;i = tr[i].next){
edge e = tr[i];
if(d[e.to] > d[x] + e.cost && e.cap){
d[e.to] = d[x] + e.cost;
pre[e.to] = i;
minflow = min(minflow,e.cap);
if(!vis[e.to]){
vis[e.to] = ;
q.push_back(e.to);
}
}
}
}
if(d[t] == INF)return false;
flow += minflow;
cost += d[t] * minflow;
for(int i = t;i != s;i = tr[pre[i]^].to){
tr[pre[i]].cap -= minflow;
tr[pre[i]^].cap += minflow;
}
return true;
}
int MCMF(int s,int t){
int flow = ,cost = ;
while(SPFA(s,t,flow,cost));
return cost;
}
int main(){
scanf("%d%d",&n,&m);
init();
for(int i = ;i <= m;++i){
scanf("%d%d%d",&reach[i],&cost[i],&stay[i]);
rid[i] = *i;cid[i] = *i-;
add(cid[i],rid[i],,-cost[i]);
}
for(int i = ;i <= m;++i){
for(int j = ;j <= m;++j){
if(j != i)
if(reach[i] + stay[i] < reach[j]){
add(rid[i],cid[j],,);
}
}
}
int S = ,T = *m+,ST = *m+;
for(int i = ;i <= m;++i){
add(S,cid[i],,);
}
for(int i = ;i <= m;++i){
add(rid[i],T,,);
}
add(T,ST,n,);
ans = double(MCMF(S,ST))/;
printf("%0.2lf\n",-ans);
return ;
}
如果大家认为有用的话,欢迎转载。如果大家有意见的话,请在下方评论栏中给我留言,或者给我的E-mail PC-worker@outlook.com发邮件留言。谢谢大家。
习题:codevs 1035 火车停留解题报告的更多相关文章
- wikioi 1035 火车停留 裸费用流
链接:http://wikioi.com/problem/1035/ 怎么说呢,只能说这个建图很有意思.因为只有m条道,然后能互相接在一起的连通,对每个点进行拆点,很有意思的一道裸费用留题. 代码: ...
- 习题:codevs 2822 爱在心中 解题报告
这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...
- 习题: codevs 2492 上帝造题的七分钟2 解题报告
这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...
- 习题:codevs 1519 过路费 解题报告
今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...
- [置顶] 刘汝佳《训练指南》动态规划::Beginner (25题)解题报告汇总
本文出自 http://blog.csdn.net/shuangde800 刘汝佳<算法竞赛入门经典-训练指南>的动态规划部分的习题Beginner 打开 这个专题一共有25题,刷完 ...
- LeetCode: Sort Colors 解题报告
Sort ColorsGiven an array with n objects colored red, white or blue, sort them so that objects of th ...
- CH Round #56 - 国庆节欢乐赛解题报告
最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...
- 二模13day1解题报告
二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...
- BZOJ 1051 最受欢迎的牛 解题报告
题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4438 Solved: 2353[S ...
随机推荐
- 18.实现如下类之间的继承关系,并编写Music类来测试这些类。
package zhongqiuzuoye; public class Instrument { public void play() { System.out.println("弹奏乐器& ...
- JsBridge实现Javascript和Java的互相调用
前端网页Javascript和Native互相调用在手机应用中越来越常见,JsBridge是最常用的解决方案. 在Android开发中,能实现Javascript与Native代码通信的,有4种途径: ...
- iOS $299刀企业证书申请的过程以及细节补充
最近申请了iOS的 299刀企业证书,相关过程有些问题,分享出来,以便后来人参考. 申请的过程我主要参考了别人以前的文章,链接如下: 1.https://developer.apple.com/cn/ ...
- 引入CSS文件的@import与link的权重分析
我很少在CSS用到@import这个标签,最近看到一句话“link方式的样式的权重 高于@import的权重”,感觉不太对,@import只是一个引入外部文件而已,怎么会有高于link的权重呢?于是我 ...
- CSS中如何实现未知尺寸图片垂直居中
在曾经的 淘宝UED 招聘 中有这样一道题目: “使用纯CSS实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中.” 当然出题并不是随意,而是有其现实的原因,垂直居中 ...
- CSS3入门之文本与字体
1.CSS3文本效果 1.1.text-shadow文本阴影 语法:text-shadow: h-shadow v-shadow blur color;(<水平阴影>,<垂直阴影&g ...
- SQL*Loader之CASE5
CASE5 1. SQL脚本 [oracle@node3 ulcase]$ cat ulcase5.sql set termout off rem host write sys$output &quo ...
- c#Dictionary键值对的使用
直接粘代码吧 using System; using System.Collections.Generic; using System.Linq; using System.Text; using S ...
- MySQL(Navicat)运行.sql文件时报错:[Err] 2006 - MySQL server has gone away 的解决方法
背景: 今天导入一个数据量很大的.sql文件时,报错: 原因: 可能是sql语句过长,超过mysql通信缓存区最大长度. 解决:1. 编辑 MySQL 安装目录下的 my.ini,在最后添加以下内容: ...
- MySQL修改默认字符集
今天朋友在做某个程序项目时,需要修改MySQL修改默认字符集,搞不好找我帮忙.百度了试了好几篇博文中的方法,最后终于成功了.但是感觉那些博文思路有点乱,所以自己总结下,希望可以帮到遇到同样问题的人. ...