zoukankan      html  css  js  c++  java
  • HDU ACM 1068 最大独立集

    意甲冠军:n同学。有些学生将有宿命的男性和女性成为恋人。收集注定要成为爱好者求学生的最大数目不存在。

    分析:独立设置,顶点设定图的一个子集,在休闲2不连续;
    二分图:最大独立集 = 顶点 - 匹配的最大数。


    这个问题是从整个点集搜索,分开成(A)(B),即(1->2)(2->1)对称存在,所以相当于搜索了两遍。因此真正最大匹配数等于最大匹配数/2。

    #include<iostream>
    using namespace std;
    
    #define N 1001
    bool map[N][N];
    int n;
    int link[N];
    bool vis[N];
    
    bool Find(int a)            //找到匹配
    {
    	int i;
    
    	for(i=0;i<n;i++)
    		if(map[a][i]&& !vis[i])
    		{
    			vis[i]=true;
    			if(link[i]==-1 || Find(link[i]))
    			{
    				link[i]=a;
    				return true;
    			}
    		}
    	return false;
    }
    
    int sovle()
    {
    	int ans=0,i;
    
    	memset(link,-1,sizeof(link));
    	for(i=0;i<n;i++)
    	{
    		memset(vis,false,sizeof(vis));
    		if(Find(i)) ans++;               //若能找到匹配
    	}
    
    	return ans;
    }
    
    
    int main()      
    {
    	int i,j,m,a,b;
    
    	while(scanf("%d",&n)==1)
    	{
    		memset(map,0,sizeof(map));
    		for(i=1;i<=n;i++)
    		{
    			scanf("%d: (%d)",&a,&m);
    			for(j=0;j<m;j++)
    			{
    				scanf("%d",&b);
    				map[a][b]=1;
    			}
    		}
    		printf("%d
    ",n-sovle()/2);
    	}
        return 0;      
    }
    


  • 相关阅读:
    关于《iBoard 电子学堂》的学习及进阶方式(精 转)
    OV7670 RAW输出 bayer 解码
    yuv和yCbCr的差异
    LeetCode--Anagrams
    LeetCode--N-Queens
    LeetCode--Gas Station
    GDB调试(转)
    LeetCode--Word Search
    Ptrace_scope的作用及设置
    LeetCode--Gray Code
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5047055.html
Copyright © 2011-2022 走看看