[SCOI2007]修车 BZOJ1070
很久之前写的题了,今天翻出来写一篇博客复习一下...
分析:
考虑,T <= 1000,并不能针对这一维处理,所以考虑将,每个人拆点,之后,拆完之后表示,这个人第n-j+1个修k这辆车,也就是,m*(i-1)+j向n*m+k连边,流量为1,费用为t[i][k]*j,之后建图跑费用流。
BZOJ上我之前跑过去了,但是现在改时间限制了...现在跑不过了...不过luogu上没有问题...
附上代码:
#include <cstdio>
#include <algorithm>
#include <iostream>
#include <queue>
#include <cmath>
#include <cstring>
using namespace std;
#define N 2005
#define S 0
#define T 2004
int head[N],cnt,n,m;
struct node
{
int to,next,val,flow,from;
}e[N*40];
inline void add(int x,int y,int z,int v)
{
e[cnt].from=x;
e[cnt].to=y;
e[cnt].next=head[x];
e[cnt].val=v;
e[cnt].flow=z;
head[x]=cnt++;
e[cnt].from=y;
e[cnt].to=x;
e[cnt].next=head[y];
e[cnt].val=-v;
e[cnt].flow=0;
head[y]=cnt++;
return ;
}
int vis[N],dis[N],que[N];
int fro[N];
int spfa()
{
memset(fro,-1,sizeof(fro));
memset(dis,0x3f,sizeof(dis));
int l=0,r=0;
que[r++]=S;
vis[S]=1;
dis[S]=0;
while(l<r)
{
int x=que[l++];
vis[x]=0;
for(int i=head[x];i!=-1;i=e[i].next)
{
int to1=e[i].to;
if(e[i].flow&&dis[to1]>dis[x]+e[i].val)
{
dis[to1]=dis[x]+e[i].val;
fro[to1]=i;
if(!vis[to1])
{
que[r++]=to1;
vis[to1]=1;
}
}
}
}
if(dis[T]>(1<<25))
{
return 0;
}
return 1;
}
inline void update(int i,int c)
{
e[i].flow-=c;
e[i^1].flow+=c;
return ;
}
int ans;
void mcf()
{
int i,x=1<<30;
i=fro[T];
while(i!=-1)
{
x=min(e[i].flow,x);
i=fro[e[i].from];
}
i=fro[T];
while(i!=-1)
{
e[i].flow-=x;
e[i^1].flow+=x;
ans+=x*e[i].val;
i=fro[e[i].from];
}
}
int t[105][105];
int main()
{
for(int i=0;i<N;i++)
{
head[i]=-1;
}
scanf("%d%d",&m,&n);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
scanf("%d",&t[i][j]);
}
}
for(int i=1;i<=n*m;i++)
{
add(0,i,1,0);
}
for(int i=n*m+1;i<=n*m+n;i++)
{
add(i,T,1,0);
}
for(int i=1;i<=m;i++)
{
for(int j=1;j<=n;j++)
{
for(int k=1;k<=n;k++)
{
add((i-1)*n+j,m*n+k,1,t[k][i]*j);
}
}
}
while(spfa())
{
mcf();
}
printf("%.2lf\n",(1.0*ans)/(1.0*n));
return 0;
}
[SCOI2007]修车 BZOJ1070的更多相关文章
- 【BZOJ1070】[SCOI2007]修车
[BZOJ1070][SCOI2007]修车 题面 以后要多写题面flag 题目描述 同一时刻有\(N\)位车主带着他们的爱车来到了汽车维修中心.维修中心共有\(M\)位技术人员,不同的技术人员对不同 ...
- 【BZOJ1070】[SCOI2007]修车 费用流
[BZOJ1070][SCOI2007]修车 Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的. ...
- [bzoj1070][SCOI2007]修车_费用流
修车 bzoj-1070 SCOI-2007 题目大意:有m个人要修n台车,每个工人修不同的车的时间不同,问将所有的车都修完,最少需要花费的时间. 注释:$2\le m\le 9$,$1\le n \ ...
- [BZOJ1070][SCOI2007]修车 费用流
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 6209 Solved: 2641[Submit][Status] ...
- bzoj1070: [SCOI2007]修车(费用流)
1070: [SCOI2007]修车 题目:传送门 题解: 一道挺简单的费用流吧...胡乱建模走起 贴个代码... #include<cstdio> #include<cstring ...
- BZOJ 1070: [SCOI2007]修车 [最小费用最大流]
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 4936 Solved: 2032[Submit][Status] ...
- 【BZOJ】1070: [SCOI2007]修车
1070: [SCOI2007]修车 Description 同 一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需 ...
- bzoj 1070: [SCOI2007]修车 费用流
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2785 Solved: 1110[Submit][Status] ...
- bzoj 1070 [SCOI2007]修车(最小费用最大流)
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 3515 Solved: 1411[Submit][Status] ...
随机推荐
- 实验:JS判断浏览器中英文版本
<script type="text/javascript"> var lang = (navigator.systemLanguage?navigator.syste ...
- zigzag方式编码
按以下公式转换: ParameterInteger = (value << 1) ^ (value >> 31) 参数值不支持大于pow(2,31) - 1或-1 * (pow ...
- Android 编程下的 TraceView 简介及其案例实战
TraceView 是 Android 平台配备一个很好的性能分析的工具.它可以通过图形化的方式让我们了解我们要跟踪的程序的性能,并且能具体到 method.详细内容参考:Profiling with ...
- linux chmod 给目录或文件赋权限 可读可写可执行
前提: mode权限设定字串,格式:[ugoa...][[+-=][rwxX]...][,...] 其中u表示拥有者(user),g表示与拥有者属于同一个群体(group),o表示其他以外的人(ot ...
- Python网络爬虫笔记(一):网页抓取方式和LXML示例
(一) 三种网页抓取方法 1. 正则表达式: 模块使用C语言编写,速度快,但是很脆弱,可能网页更新后就不能用了. 2. Beautiful Soup 模块使用Python编写,速度慢. ...
- 【python】字典/dictionary操作
字典(dictionary) 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key=>value 对用冒号:分割,每个键值对之间用逗号,分割,整个字典包括在花括号 {} 中 ...
- 为notifyIcon.icon属性赋图片
System.Drawing.Bitmap bp; bp = new Bitmap(Application.StartupPath + @"\image\" + MeiYeShuo ...
- Oracle 数据库 简单查询
select DISTINCT dept_id from s_emp; desc s_emp; ; --给入职3年以上员工发10万元年终奖 ; --列出职位是仓库管理员的名字和工资 select la ...
- ShellCode初体验
写在前面的话: ShellCode是一门艺术,就像围棋手门追求的“神之一手”,今天就来初探一下这让人疯狂的艺术: 零.代码0 相信手写opcode,目前很少有人干了,其实,也确实已经没有这个必要了,毕 ...
- MySql详解(三)
MySql详解(三) 导入基础表 具体的SQL文件已经放入百度网盘,连接为:http://pan.baidu.com/s/1hseoVR2,后面的MySql内容都是按照这些基础表展开的. depart ...