poj 2536 二分匹配
来源:互联网 发布:2010江苏高考数学知乎 编辑:程序博客网 时间:2024/06/05 00:11
简单二分匹配,注意,输出的是n-最大匹配数
#include<stdio.h>#include<string.h>#include<math.h>int match[110];bool map[110][110];struct point{double x,y;}p[110],hole[110];double dis(point a,point b){return sqrt((a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y));}bool vis[110];int m;bool dfs(int u){int i;for(i=0;i<m;i++){if(map[u][i]&&!vis[i]){vis[i]=true;if(match[i]==-1||dfs(match[i])){match[i]=u;return true;}}}return false;}int main(){int n,s,v;int i,j,k;while(scanf("%d%d%d%d",&n,&m,&s,&v)!=EOF){memset(map,false,sizeof(map));memset(match,-1,sizeof(match));for(i=0;i<n;i++)scanf("%lf%lf",&p[i].x,&p[i].y);for(i=0;i<m;i++)scanf("%lf%lf",&hole[i].x,&hole[i].y);for(i=0;i<n;i++){for(j=0;j<m;j++){if(dis(p[i],hole[j])/v<=1.0*s){map[i][j]=true;}}}int ans=0;for(i=0;i<n;i++){memset(vis,false,sizeof(vis));if(dfs(i))ans++;}printf("%d\n",n-ans);}return 0;}
- poj 2536 二分匹配
- POJ 2536 Gopher II 二分匹配
- 【POJ】2536 Gopher II 二分匹配
- poj 2536 二分图 最大匹配
- POJ 2536 - Gopher II(二分图匹配)
- POJ 2536 Gopher II 二分图匹配
- poj (3343)二分匹配+二分
- poj 2060 二分匹配
- poj 1274(二分匹配)
- POJ 3020 二分匹配
- poj 3041 二分匹配
- poj 1466二分匹配
- poj 1325 二分匹配
- poj 2724 二分匹配
- poj 3692(二分匹配)
- poj 2446 二分匹配
- poj 3020 (二分匹配)
- poj 2446 (二分匹配)
- hdu 1203 01背包
- hdu 2955 Robberies 01背包
- hdu 3033 分组背包 每组至少选一个
- hdu 1712 分组背包 每组至多取一个背包
- poj 2723 2-sat
- poj 2536 二分匹配
- poj 2537 DP
- 关于分组背包
- hdu 3535 终极版解题报告
- zstu 1032 拆分物品 再01背包
- poj 1384 完全背包
- poj 1252 完全背包
- poj 3468 A Simple Problem with Integers
- poj 2063 多次完全背包