[BZOJ1070][SCOI2007]修车 费用流
1070: [SCOI2007]修车
Time Limit: 1 Sec Memory Limit: 128 MB
Submit: 6209 Solved: 2641
[Submit][Status][Discuss]
Description
同一时刻有N位车主带着他们的爱车来到了汽车维修中心。维修中心共有M位技术人员,不同的技术人员对不同
的车进行维修所用的时间是不同的。现在需要安排这M位技术人员所维修的车及顺序,使得顾客平均等待的时间最
小。 说明:顾客的等待时间是指从他把车送至维修中心到维修完毕所用的时间。
Input
第一行有两个m,n,表示技术人员数与顾客数。 接下来n行,每行m个整数。第i+1行第j个数表示第j位技术人
员维修第i辆车需要用的时间T。
Output
最小平均等待时间,答案精确到小数点后2位。
Sample Input
3 2
1 4
Sample Output
HINT
数据范围: (2<=M<=9,1<=N<=60), (1<=T<=1000)
我们先将所有m拆成n个点,每个点表示m倒数第i个维修的车。
对于每一辆车,我们向所有m拆的点连边,容量为1,费用为cost[i][j]*i表示他花的时间和后i个人等待的时间和。
跑最小费用最大流。
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<cstdlib>
- #include<cmath>
- #include<algorithm>
- #define maxn 700
- using namespace std;
- int n,m;
- int a[][];
- int t;
- bool vis[maxn];
- int dis[maxn];
- struct data {
- int to,next,c,w;
- }e[maxn*maxn];
- int head[maxn],cnt;
- int q[maxn];
- void add(int u,int v,int w,int c){e[cnt].next=head[u];e[cnt].to=v;e[cnt].c=c;e[cnt].w=w;head[u]=cnt++;}
- int use=;
- bool spfa() {
- for(int i=;i<=t;i++) dis[i]=-;
- memset(vis,,sizeof(vis));
- int h=,tail=;
- q[]=t;
- dis[t]=;
- vis[t]=;
- while(h!=tail) {
- int now=q[h++];if(h==maxn) h=;
- for(int i=head[now];i>=;i=e[i].next) {
- int to=e[i].to;
- if(e[i^].w>&&dis[to]<dis[now]+e[i].c) {
- dis[to]=dis[now]+e[i].c;
- if(!vis[to]){
- vis[to]=;
- q[tail++]=to;if(tail==maxn) tail=;
- }
- }
- }
- vis[now]=;
- }
- use-=dis[];
- return dis[]!=-;
- }
- int ans=;
- int dfs(int now,int af) {
- if(now==t||af==){ans+=use*af;return af;}
- vis[now]=;
- int flow=,f=;
- for(int i=head[now];i>=;i=e[i].next) {
- int to=e[i].to;
- if(vis[to]) continue;
- if(dis[to]==dis[now]+e[i].c&&e[i].w>&&(f=dfs(to,min(af,e[i].w)))) {
- e[i].w-=f;
- e[i^].w+=f;
- flow+=f;
- af-=f;
- if(!af) break;
- }
- }
- return flow;
- }
- void zkw() {
- while(spfa()) {
- do {
- memset(vis,,sizeof(vis));
- }while(dfs(,));
- memset(vis,,sizeof(vis));
- use=;
- }
- }
- int main() {
- memset(head,-,sizeof(head));
- scanf("%d%d",&m,&n);
- for(int i=;i<=n;i++)
- for(int j=;j<=m;j++) scanf("%d",&a[i][j]);
- for(int i=;i<=n;i++) {add(,i,,);add(i,,,);}
- t=;
- for(int i=n+;i<=n+n*m;i++) {add(i,t,,);add(t,i,,);}
- for(int i=;i<=n;i++) {
- for(int j=n+;j<=n+n*m;j++){
- int cost=j-n;
- int temp=cost/n+;
- cost%=n;
- if(!cost) cost=n,temp--;
- add(i,j,,a[i][temp]*cost);
- add(j,i,,-a[i][temp]*cost);
- }
- }
- zkw();
- double ans1;
- ans1=(double)ans/(double)n;
- printf("%.2lf",ans1);
- }
[BZOJ1070][SCOI2007]修车 费用流的更多相关文章
- [bzoj1070][SCOI2007]修车——费用流
题目大意: 传送门 题解: 本题和(POJ3686)[http://poj.org/problem?id=3686]一题一模一样,而且还是数据缩小以后的弱化版QAQ,<挑战程序设计竞赛>一 ...
- [BZOJ1070] [SCOI2007] 修车 (费用流 & 动态加边)
Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使 ...
- 【BZOJ1070】[SCOI2007]修车 费用流
[BZOJ1070][SCOI2007]修车 Description 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的. ...
- bzoj 1070: [SCOI2007]修车 费用流
1070: [SCOI2007]修车 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2785 Solved: 1110[Submit][Status] ...
- P2053 [SCOI2007]修车 费用流
$ \color{#0066ff}{ 题目描述 }$ 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M ...
- 【BZOJ 1070】[SCOI2007]修车 费用流
就是拆个点限制一下(两点一排一大片),这道题让我注意到了限制这个重要的词.我们跑网络流跑出来的图都是有一定意义的,一般这个意义就对应了问题的一种方案,一般情况下跑一个不知道对不对的方案是相对容易的我们 ...
- [SCOI2007]修车 费用流
---题面--- 题解: 因为我们并不需要知道准确方案,而人数固定,要使得平均等待时间最小,也就是要使得总的等待时间最小. 因此我们将工人按每个时刻拆点,拆完之后向车子连边,流量为1,费用为k * 维 ...
- [SCOI2007]修车 费用流 BZOJ 1070
题目描述 同一时刻有N位车主带着他们的爱车来到了汽车维修中心.维修中心共有M位技术人员,不同的技术人员对不同的车进行维修所用的时间是不同的.现在需要安排这M位技术人员所维修的车及顺序,使得顾客平均等待 ...
- BZOJ.1070.[SCOI2007]修车(费用流SPFA)
题目链接 /* 神tm看错题*2.. 假如人员i依次维修W1,W2,...,Wn,那么花费的时间是 W1 + W1+W2 + W1+W2+W3... = W1*n + W2*(n-1) + ... + ...
随机推荐
- Java-JNA使用心得
自上个月20号,历时整整一个月,终于找到工作入职了. 然后这段时间一直看公司的框架还有业务方面的东西.其实由于给分配了一个研究Java调用C语言接口的问题,导致框架业务方面的东西还不熟,然后现在手上又 ...
- DOS程序员手册(十五)
837页 writeln('TRACING Current Buffer==='); holdup; bcbtrc(cvtbase^.curbfr); writeln; holdup ; writel ...
- USACO Section1.5 Number Triangles 解题报告
numtri解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...
- iOS-QQ好友列表实现
0.QQ好友列表实现 0.首先说说实现思路 自定义UITableView,每一个分组都是一个UITableViewHeaderFooterView,然后自定义cell,这里分组的实现主要是自定义UIT ...
- Java基础-4变量与数据类型
变量:变量是Java程序中的一个基本存储单元.变量是一个标识符.类型及一个可选初始值的组合定义.所有的变量都有一个作用域,即变量在某一区域有效. 基本的变量声明方式如下: int a; float b ...
- python 学习分享-实战篇高级的ftp
#server代码 import socketserver,os,hashlib Base_paht = os.path.dirname(os.path.dirname(os.path.abspath ...
- [Ceres]C++优化库
官网教程: http://ceres-solver.org/nnls_tutorial.html 定义了一个最小二乘法求解器 自动求导的功能
- C# 命名管道
有些场合需要高效率,进行线程间通信,可以使用 C#命名管道.
- jQuery基础知识点(下)
在实际开发中,jQuery的实践性非常强大.上一篇本人已经整理出了一部分基础知识点,该文即是对以上的补充和扩展. 1.表单值的操作 //获取文本框的值 //txt.value var val = $( ...
- php + ajax实现 帖子点赞功能
知识: 一.首先页面需要加载jquery框架 二.ajax常用参数解释: ①.type:传输数据方式,get或者post ②.url:处理数据的PHP脚本 ③.data:传输的数据索引及值,值用js获 ...