hdu1530 求最大团
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1530
求最大团裸题。
模板:maxx即为所求的最大团的值。
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; int mp[][],mark1[],mark2[];
int n,cnt,maxx; void dfs(int x)
{
if(x>n) // 如果枚举了所有的节点
{
maxx=cnt;
memcpy(mark1,mark2,sizeof(mark2)); // 用一个更大的极大团替代原有的极大团
return;
}
int flag=true;
for(int i=; i<x; i++) // 检测新加入的点是否到团中的其他节点都存在一条边
{
if(mark2[i] && !mp[i][x])
{
flag=false;
break;
}
}
if(flag) // 如果该节点满足在这个团中
{
mark2[x]=,cnt++; // 该节点被加入到完全子图中去
dfs(x+);
mark2[x]=,cnt--;
}
if (cnt+n-x>maxx) // 跳过x节点进行搜索同时进行一个可行性判定
dfs(x+);
} int main()
{
while(scanf("%d",&n)== && n)
{
memset(mark1,,sizeof(mark2));
memset(mark2,,sizeof(mark2));
maxx=cnt=;
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
scanf("%d",&mp[i][j]);
dfs();
printf("%d\n",maxx);
}
return ;
}
代码1:
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; int n;
int mp[][],mark[];
int cn,maxx;
//没优化,跑9000+msvoid dfs(int x) //dfs(1);
{
if(x>n)
{
maxx=cn;
return;
}
int flag=;
for(int i=; i<x; i++)
{
if(mark[i]&&!mp[x][i])
{
flag=;
break;
}
}
if(flag)
{
cn++;
mark[x]=;
dfs(x+);
cn--;
}
if(cn+n-x+>maxx) ///这句话看了好久都没懂是什么意思
{
mark[x]=;
dfs(x+);
}
} int main()
{
while(scanf("%d",&n)== && n)
{
memset(mp,,sizeof(mp));
memset(mark,,sizeof(mark));
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
scanf("%d",&mp[i][j]);
cn=maxx=;
dfs();
printf("%d\n",maxx);
}
return ;
}
代码2:
#include<cstdio>
#include<cstring>
const int N=; //最大团模板
bool a[N][N];//a为图的邻接表(从1开始)
int cnt[N],group[N],vis[N];//cnt[N]表示当前最大团的节点数,group[N]用以寻找一个最大团集合
int n,m,ans;//ans表示最大团
//dfs(i,1);
bool dfs(int u,int pos)//u为当从前顶点开始深搜,pos为深搜深度(即当前深搜树所在第几层的位置)
{
int i,j;
for(i=u+; i<=n; i++)//按递增顺序枚举顶点
{
if(cnt[i]+pos<=ans) return ;//剪枝
if(a[u][i])
{
//与目前团中元素比较,取 Non-N(i)
for(j=; j<pos; j++)
if(!a[i][vis[j]])
break;
if(j==pos)
{
//若为空,则皆与 i 相邻,则此时将i加入到 最大团中
vis[pos]=i;//深搜层次也就是最大团的顶点数目,vis[pos]=i表示当前第pos小的最大团元素为i(因为是按增顺序枚举顶点 )
if(dfs(i, pos+)) return ;
}
}
}
if(pos>ans)
{
for(i=; i<pos; i++)
group[i]=vis[i]; // 更新最大团元素
ans=pos;
return ;
}
return ;
} void maxclique()//求最大团
{
ans=-;
for(int i=n; i>; i--)
{
vis[]=i;
dfs(i,);
cnt[i]=ans;
}
}
int main()
{
while(scanf("%d",&n)== && n)
{
if(n==) break;
int x,y;
memset(a,,sizeof(a));
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
scanf("%d",&a[i][j]);
maxclique();
if(ans<) ans=;//ans表示最大团
printf("%d\n",ans);
}
}
代码3:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std; int n,path[][],s[],dp[],ans; bool is_clique(const int ed,const int point)
{
for(int i=; i<ed; i++)
if(!path[s[i]][point]) return false;
return true;
} void dfs(int depth,int now)
{
if(depth+n-now+<=ans||depth+dp[now]<=ans) return;
for(int i=now; i<=n; i++)
{
if(is_clique(depth+,i))
{
s[depth+]=i;
dfs(depth+,i+);
}
}
if(depth>ans) ans=depth;
} int main()
{
while(scanf("%d",&n)== && n)
{
for(int i=; i<=n; i++)
for(int j=; j<=n; j++)
scanf("%d",&path[i][j]);
memset(dp,,sizeof(dp));
ans=;
dp[n]=;
for(int i=n-; i>=; i--)
{
s[]=i;
dfs(,i+);
dp[i]=ans;
}
printf("%d\n",dp[]);
}
return ;
}
hdu1530 求最大团的更多相关文章
- HDU1530(最大团)
Given a graph G(V, E), a clique is a sub-graph g(v, e), so that for all vertex pairs v1, v2 in v, th ...
- HDU1530 最大团 模板
Maximum Clique Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- hdu 1530 最大团模板
说明摘自:pushing my way 的博文 最大团 通过该博主的代码,总算理解了最大团问题,但是他实现时的代码效率却不算太高.因此在最后献上我的模板.加了IO优化目前的排名是: 6 yejinru ...
- ZOJ 1492 Maximum Clique 搜索最大团
ZOJ1492 题意:给一个无向图 求最大团的大小.节点数小于50 数据有限,考虑记忆化搜索,方程很好给出. 令 Si={vi,vi+1.....vn} mc[i]表示Si最大团的大小,倒着推算. 必 ...
- CF1105E Helping Hiasat 最大团
传送门 发现自己不会求最大团了可海星 如果将每一个朋友看做点,将两个\(1\)之间存在\(2\)操作的所有朋友之间互相连边,那么我们最后要求的就是这个图的最大独立集. 某个图的最大独立集就是反图的最大 ...
- DFS剪枝,最大团,POJ(1419)
题目链接:http://poj.org/problem?id=1419 题目大意:一个无向图,用黑白涂色,相邻的两个点不能图同一种颜色,求黑色的点最多有几个? 刚一看题,完全是图的m着色问题啊,我就套 ...
- 2019 牛客多校五 F. maximum clique 1 (最大团)
大意: 给定$n$个互不相同的数, 若两个数异或后二进制中$1$的个数不少于$2$则连边, 求最大团. 最大团转为补图最大独立集. 可以发现补图是二分图, 所以直接$dinic$即可. 最大独立集相当 ...
- POJ 3692 幼儿园做游戏 最大团 模板题
Kindergarten Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 6191 Accepted: 3052 Desc ...
- CF839E Mother of Dragons 最大团 Bron-Kerbosch算法
题意简述 给你一个\(n\)个节点的无向图\(G=\{V,E\}\)的邻接矩阵\(g\)和每个点的点权为\(s_i\),且\(\sum_{i=1}^n s_i = K\),要你求出\(\mathrm{ ...
随机推荐
- 解决WordPress安装主题/插件提示输入FTP帐号的问题
有时比较着急想要安装一款主题或插件,却提示需要输入 FTP 帐号密码……这种情况蛮让人讨厌的,以下就是最完美的解决方法: 方法一:在 wp-config.php 文件加入代码 如果使用的是虚拟主机,可 ...
- HDU 6437 最(大) 小费用最大流
Problem L.Videos Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 524288/524288 K (Java/Other ...
- Codeforces 703C(计算几何)
C. Chris and Road time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...
- T1503 愚蠢的宠物 codevs
http://codevs.cn/problem/1503/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 大家都知道,sh ...
- springboot整合mybatis,freemarker
springboot 整合mybaits,,freemarker pom.xml文件 <?xml version="1.0" encoding="UTF-8&quo ...
- 30分钟学会如何使用Shiro(转)
本文转自http://www.cnblogs.com/learnhow/p/5694876.html 感谢作者 本篇内容大多总结自张开涛的<跟我学Shiro>原文地址:http://jin ...
- SYSTEM 表空间管理及备份恢复
标签: systemoraclesqldatabasefile数据库 2010-11-28 18:14 12689人阅读 评论(0) 收藏 举报 分类: -----Oracle备份恢复(16) 版权声 ...
- PHP的类中的常量,静态变量的问题。
自己在写一个小型的 angularJS 库的时候,觉得 javascript 中的很多概念有点像是PHP中的概念. 像类常量, 类中的静态变量(类的静态变量是类的所有实例都共享的),这些概念虽然在 j ...
- 项目中遇到的HQL查询问题
问题描写叙述: 目的:想要查询出全部最新版本号的组件 说明:组件:版本号 =1:n关系 ,假设这个组件仅仅有一个版本号也要可以查出来. 项目中使用的是内存数据库,无法看到表结构,这里的样例仅仅用于模拟 ...
- Swift基础一(代码)
import Foundation println("Hello, World!") var string1 = "Hello BeiJing" //定义一个变 ...