POJ3216 最小路径覆盖
首先说一下题意,Q个区域,M个任务,每个区域任务可能有多个,然后给你个到各地所需时间的矩阵,每个任务都有开始和持续时间,问最少需要多少工人? 每个工人只能同时执行一个任务。
通过题意,我的瞬间反应就是先把点拆开再说,因为每个区域可能有多个任务,所以把每个任务都当做一点处理,之后就需要考虑一件事情,一个工人在Qi区域做完之后是不是应该去一个离他最近且正好有任务的地方Qj,那么他从Qi到Qj是不是应该走最近的路线? 下一步就出来了,求出所有区域之间的最短距离,用floyd一键搞定。然后就可以建图(有向的)了,把能衔接起来的任务统统连上,按照上一个任务的开始时间+持续时间+到下一点的时间<=下一点的开始时间来连边(不用换区域的到下一点的时间为零),那么此时的问题就变成了多少个工人能把图走完? 即最小路径覆盖,直接匈牙利算法搞定。
好了上代码
#include<cstdio>
#include<cstring>
#include<iostream>
#include<vector>
#define maxn 500
#define inf 0xfffffff
using namespace std; struct edge
{
int pos,realpos,start,need;
}rela[maxn];
vector<int> q[maxn];
int mize[maxn][maxn],point[maxn];
int vis[maxn],link[maxn];
int n,m,sum;
void init()
{
for(int i=;i<=maxn;i++)
q[i].clear();
memset(rela,,sizeof(rela));
memset(mize,,sizeof(mize));
memset(point,,sizeof(point));
for(int a=;a<=n;a++)
for(int b=;b<=n;b++)
{
scanf("%d",&mize[a][b]);
if(mize[a][b]==-) mize[a][b]=inf;
} for(int c=;c<=m;c++)
{
scanf("%d %d %d",&rela[c].pos,&rela[c].start,&rela[c].need);
int p=;
for(int d=;d<c;d++)
{
if(rela[d].pos==rela[c].pos) p++;
}
rela[c].realpos=rela[c].pos+n*p;
point[rela[c].realpos]=;
if(sum<rela[c].realpos) sum=rela[c].realpos;
}
}
void floyd()
{
for(int i=;i<=n;i++)
{
for(int j=;j<=n;j++)
{
for(int k=;k<=n;k++)
{
mize[j][k]=mize[j][k]<mize[i][k]+mize[j][i]?mize[j][k]:mize[i][k]+mize[j][i];
}
}
} }
void set_map()
{
for(int i=;i<=m;i++)
{
int realpos=rela[i].realpos,pos=rela[i].pos,time=rela[i].need+rela[i].start;
for(int j=;j<=m;j++)
{
if(j==i) continue;
int a=rela[j].realpos,b=rela[j].pos,t=rela[j].start;
// if(mize[pos][b]==-1||mize[b][pos]==-1) continue;
if(time+mize[pos][b]<=t) // 矩阵式对称的 怎么写都无所谓
{
q[realpos].push_back(a);
// q[a].push_back(realpos);
}
}
}
/* for(int i=1;i<=8;i++)
{
if(q[i].size()==0) continue;
cout<<i<<": "<<endl;
for(int j=0;j<q[i].size();j++)
{
cout<<q[i][j]<<" ";
}
cout<<endl;
}*/
}
int dfs(int x)
{
for(int i=;i<q[x].size();i++)
{
int y=q[x][i];
if(!vis[y])
{
vis[y] = true;
if(link[y]== -||dfs(link[y]))
{
link[y] = x;
return true;
}
}
}
return false;
}
void solve()
{
int s=;
memset(link,-,sizeof(link));
for(int i=;i<=sum;i++)
{
if(point[i]==) continue;
memset(vis,,sizeof(vis));
if(dfs(i)) s++;
}
printf("%d\n",m-s);
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
if(n==&&m==) break;
sum=;
init();
floyd();
set_map();
solve();
}
return ;
}
POJ3216 最小路径覆盖的更多相关文章
- 【HDU1960】Taxi Cab Scheme(最小路径覆盖)
Taxi Cab Scheme Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- loj 1429(可相交的最小路径覆盖)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1429 思路:这道题还是比较麻烦的,对于求有向图的可相交的最小路径覆盖,首先要解决成环问 ...
- 【HDU3861 强连通分量缩点+二分图最小路径覆盖】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3861 题目大意:一个有向图,让你按规则划分区域,要求划分的区域数最少. 规则如下:1.有边u到v以及有 ...
- POJ 3216 最小路径覆盖+floyd
Repairing Company Time Limit: 1000MS Memory Limit: 131072K Total Submissions: 6646 Accepted: 178 ...
- POJ3020Antenna Placement(最小路径覆盖+重在构图)
Antenna Placement Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 7788 Accepted: 3880 ...
- POJ 3020 (二分图+最小路径覆盖)
题目链接:http://poj.org/problem?id=3020 题目大意:读入一张地图.其中地图中圈圈代表可以布置卫星的空地.*号代表要覆盖的建筑物.一个卫星的覆盖范围是其周围上下左右四个点. ...
- 【wikioi】1904 最小路径覆盖问题(最大流+坑人的题+最小路径覆盖)
http://wikioi.com/problem/1904/ 这题没看数据的话是一个大坑(我已报告官方修复了),答案只要求数量,不用打印路径...orz 最小路径覆盖=n-最大匹配,这个我在说二分图 ...
- hiho 第118周 网络流四·最小路径覆盖
描述 国庆期间正是旅游和游玩的高峰期. 小Hi和小Ho的学习小组为了研究课题,决定趁此机会派出若干个调查团去沿途查看一下H市内各个景点的游客情况. H市一共有N个旅游景点(编号1..N),由M条单向游 ...
- 【网络流24题----03】Air Raid最小路径覆盖
Air Raid Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
随机推荐
- Java中的break循环——通过示例学习Java编程(13)
作者:CHAITANYA SINGH 来源:https://www.koofun.com//pro/kfpostsdetail?kfpostsid=24 break语句通常用于以下两种情况: (A)使 ...
- css设置文字超出部分显示省略号。。。
兼容IE/Firefox/Chrome display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
- java的三大特性之一继承概述
0.继承-----注意事项 00.子类最多只能继承一个父类(指直接继承) 01.java所有的类都是Object的子类 02.JPK6.0中有202个包3777个类,接口,异常,枚举,注释和错误 03 ...
- 洛谷 P1690 贪婪的Copy
题目 本题难度较低,操作比较简单,首先对于范围较小的N(<=100),我们可以先跑一遍floyd,求出任意两点之间的最短路.对于很小的p(<=15),我们可以直接考虑全排列,运用到next ...
- python3 socke 服务端与客户端实现(回炉)
#服务端#!/usr/bin/env python3 # -*- coding:utf-8 -*- from socket import * # 创建socket tcpSerSocket = soc ...
- win10 vm 11 桥接模式配置
1 保证你Vmware里面的虚拟机是关机状态 2 在本地连接 属性中 卸载VM 桥接协议 3 管理员身份运行VM ,编辑>虚拟网络编辑器 删除所有网卡,并且重新配置网络适配器 4 配置完成后,选 ...
- Android笔记--View绘制流程源码分析(二)
Android笔记--View绘制流程源码分析二 通过上一篇View绘制流程源码分析一可以知晓整个绘制流程之前,在activity启动过程中: Window的建立(activit.attach生成), ...
- 阻止form元素内的input标签回车提交表单
<form></form>标签内input元素回车会默认提交表单. 阻止回车默认提交表单: $('form').on('keydown', function (event) { ...
- vue跨域处理(vue项目中baseUrl设置问题)
1.开发环境: 2.生产环境: 然后 const instance = axios.create({ baseURL: process.env.API })
- java基础—java读取properties文件
一.java读取properties文件总结 在java项目中,操作properties文件是经常要做的,因为很多的配置信息都会写在properties文件中,这里主要是总结使用getResource ...