给出一些地点的出发时刻, 起点,终点,问最少需要多少辆出租车才能满足出租要求(出租车开完某趟之后可以继续开)。
现将问题转换为最小点覆盖(一辆车最多运多少趟),然后就可以直接得到最小路径覆盖了。
#include<stdio.h>
#include<string.h>
#include<vector>
#include<iostream>
#include<algorithm>
using namespace std;
#define N 505
struct node{
int a, b, c, d;
int t;
}p[N];
int link[N], vis[N];
vector<int> v[N];
int n;
int cmp(const node &q, const node &w)
{
return q.t < w.t;
}
int dfs( int u )
{
for ( int i = 0; i < v[u].size(); i++ )
{
int to = v[u][i];
if( !vis[to] )
{
vis[to] = 1;
if( link[to] == -1 || dfs( link[to] ) )
{
link[to] = u;
return 1;
}
}
}
return 0;
}
int main()
{
int tot;
for ( scanf("%d", &tot); tot--; )
{
scanf("%d", &n);
int z, x;
for( int i = 1; i <= n; i++ )
{
scanf("%d:%d", &z, &x);
scanf("%d%d%d%d", &p[i].a, &p[i].b, &p[i].c, &p[i].d);
p[i].t = z * 60 + x;
v[i].clear();
}
sort( p+1, p+1+n, cmp);
//for( int i = 1; i <= n; i++ )
//{
// printf("%d %d %d %d %d\n", p[i].a, p[i].b, p[i].c, p[i].d, p[i].t);
//}
for ( int i = 1; i <= n; i++ )
{
for( int j = i+1; j <= n; j++ )
{
if( p[j].t - p[i].t > ( abs(p[i].c - p[i].a) + abs(p[i].d - p[i].b) + abs(p[j].a - p[i].c) + abs(p[j].b - p[i].d)))
v[i].push_back(j);
}
}
int ans = 0;
memset(link, -1, sizeof(link));
for( int i = 1; i <= n; i++ )
{
memset(vis, 0, sizeof(vis));
ans += dfs(i);
}
printf("%d\n", n - ans);
}
return 0;
}