/*
匈牙利算法
二分匹配 最小点覆盖=最大匹配。
即踢掉最小点覆盖
*/
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<algorithm>
#include<iostream>
#include<queue>
#include<map>
#include<math.h>
using namespace std;
typedef long long ll;
//typedef __int64 int64;
const int maxn = 1015;
const int inf = 0x7fffffff;
const double pi=acos(-1.0);
const double eps = 1e-8;
struct Edge{
int v,next;
}edge[ maxn<<4 ];
struct Node{
int x,y;
}sum[ maxn<<1 ];
int cnt,head[ maxn<<1 ];
int vis[ maxn<<1 ],mylink[ maxn<<1 ];
void init(){
cnt = 0;
memset( head,-1,sizeof( head ) );
}
void addedge( int a,int b ){
edge[ cnt ].v = b;
edge[ cnt ].next = head[ a ];
head[ a ] = cnt++;
}
bool km( int u ){
for( int i=head[ u ];i!=-1;i=edge[ i ].next ){
int v = edge[ i ].v;
if( vis[ v ]==0 ){
vis[ v ] = 1;
if( mylink[ v ]==-1||km( mylink[v] ) ){
mylink[ v ] = u;
return true;
}
}
}
return false;
}
int solve( int n,int m ){
memset( mylink,-1,sizeof( mylink ) );
int ans = 0;
for( int i=1;i<=n;i++ ){
memset( vis,0,sizeof( vis ) );
if( km(i) )
ans++;
}
return ans;
}
bool Judge( int i,int j ){
int x1 = sum[i].x;
int y1 = sum[i].y;
int x2 = sum[j].x;
int y2 = sum[j].y;
if( x1==x2 ){
if( y1==y2 ) return true;
if( y1==y2+1 ) return true;
}
if( x1+1==x2 ){
if( y1==y2 ) return true;
if( y1==y2+1 ) return true;
}
return false;
}
int main(){
int n,m;
while( scanf("%d%d",&n,&m)==2,n+m ){
init();
int cc = 1;
for( int i=1;i<=n;i++ )
scanf("%d%d",&sum[cc].x,&sum[cc].y),cc++;
for( int j=1;j<=m;j++ )
scanf("%d%d",&sum[cc].x,&sum[cc].y),cc++;
for( int i=1;i<=n;i++ ){
for( int j=n+1;j<cc;j++ ){
if( Judge( i,j ) ){
addedge( i,j );
}
}
}
printf("%d\n",cc-1-solve( n,m ));
}
return 0;
}
分享到:
相关推荐
在ACM(国际大学生程序设计竞赛)中,HDU(杭州电子科技大学)的在线判题系统是许多参赛者磨炼算法技巧的重要平台。这个平台涵盖了众多的算法问题,旨在提升参赛者的编程能力和逻辑思维能力。以下是对标题和描述中...
### hdu题目分类知识点概述 本篇将对“hdu题目分类”中提及的各种类型问题进行详细介绍,旨在帮助读者更好地理解这些题目所涉及的核心概念和技术点,并为编程竞赛中的实战训练提供参考。以下是对每道题目的具体分析...
10. **网络流与最大匹配**:最大流、最小割、匈牙利算法等。 通过学习和练习这些平台上的题目,不仅可以提高编程技巧,还能培养良好的算法思维,这对于参加ACM(国际大学生程序设计竞赛)或其他编程竞赛至关重要。...
在HDU ACM教程中,"二分匹配及其应用"这部分内容很可能会深入讲解这些概念,包括如何构建二分图,如何使用匈牙利算法进行求解,以及如何分析和设计相关问题的解决方案。通过学习这部分内容,参赛者可以提升在算法...
HDU ACM培训资料是一系列专为参与ACM(国际大学生程序设计竞赛)的学员准备的教育资源,涵盖了算法和编程竞赛的核心知识。这份压缩包包含了11个不同主题的课时,旨在帮助学员全面掌握ACM竞赛所需的技能。下面将详细...
- **解题思路**:建立二分图,一边是男孩,另一边是女孩,然后通过匈牙利算法来寻找最大匹配。 2. **Machine Schedule (HDU 1150)** - **知识点**:最小点覆盖问题,可以转化为最大匹配问题求解。 - **解题思路...
- **【HDU 3315】Assignment 求 KM 最大时,要求改动最少**、**【HDU 3523】My Brute 求 KM 最大时,要求改动最少**:这些题目中的“KM”可能不是指KMP算法,而是指Kuhn-Munkres算法(也称匈牙利算法),用于解决赋权...
1、匈牙利算法 HDU 1150 #include #include #include using namespace std; int m,n,k; int vis[105]; int mpt[105][105]; int use[105]; int hungary(int x) { for(int i=1;i<m;i++) { if(vis[i]==0&&mpt[x]...
"(HDUACM2010版_13)二分匹配及其应用.ppt" 可能会讲解匈牙利算法或Kuhn-Munkres算法,它们可以用于解决分配问题、市场平衡等问题。掌握二分匹配不仅有助于解决实际问题,还能为学习更复杂的图论算法打下基础。 母...
【杭电ACM训练PPT】是一套针对编程竞赛,特别是杭州电子科技大学(HDU)ACM团队训练的教程资料。这些PPT涵盖了多种算法和数学概念,旨在提升参赛者在算法设计和问题解决上的能力。以下是各部分的详细解释: 1. **二...
在该文件中,1Hdu 1856 并查集是一个典型的并查集问题,要求使用并查集来解决连通性问题。解题时需要使用递归函数来找到根节点,并使用数组来存储每个节点的父节点信息。 2. 素数筛选: 素数筛选是一种常用的算法...
2.18.1 HDU4656 卷积取模 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 2.19 其它公式 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 2.19.1 Polya . . . ....